前言
近期ChatGPT爆火,其对传统文字工作的效率提高及总结能力让使用者惊艳。紧随其后CodeGPT这样基于GPT的插件出现,也充分体现了其对代码编写效率的提高。而最新GPT-4的发布,是否可以应用到对区块链、Solidity智能合约的审计中呢?
基于这样的疑问,我们进行了多种可行性测试。
测试环境及测试方法
测试使用的对比模型对象:GPT-3.5(Web),GPT-3.5-turbo-0301,GPT-4(Web)。
代码片段使用Prompt:HelpmediscovervulnerabilitiesinthisSoliditysmartcontract.
漏洞代码片段的检测对比
在此部分,我们分三次测试,使用历史上常见的漏洞代码作为测试一和测试二的用例,来验证其对基础漏洞的检测能力,测试三中使用中等难度的漏洞代码作为测试用例。
测试一
用例:《智能合约安全审计入门篇——Phishingwithtx.origin》
漏洞代码:
彭博社:8月加密市场因DeFi火爆增加超500种新代币:由于DeFi热潮涌动,2020年8月加密货币市场已经增加超500种新代币,或导致加密泡沫再次变得越来越大。在投机欲望激增的推动下,猪排(Porkchop)、Davecoin、意面(PASTA)、寿司(Sushiswap)Newtonium等新代币纷纷登场,许多项目没有实际效用,但投资者已经投入数十亿美元。根据DeFi市场数据提供商DeFi Pulse数据显示,截至9月2日,用户向所有DeFi应用程序投入的资金超过94.6亿美元。(彭博社)[2020/9/2]
对GPT进行提问:
GPT-3.5(Web)answer
GPT-3.5-turbo-0301answer
GPT-4(Web)answer
杨东:区块链比人工智能维度更高,火爆是必然的:据《中国产经新闻》报道,中国人民大学大数据区块链与监管科技实验室主任杨东在接受记者采访时曾表示,区块链作为信任传递的工具,能够在没有中心化节点的前提下实现陌生人之间的可信记账,从而为金融交易和经济生活的其他方面带来巨大的机遇。有人曾称区块链是比人工智能更伟大的技术,这句话不无道理。从维度上来看,人工智能更主要是解决生产力,而区块链更多的是解决生产关系,所以区块链比人工智能维度更高,因此对经济社会国家,乃至个人更具广泛的影响和冲击,因此区块链火爆是必然的。[2018/5/26]
可以看到结果:3个测试版本都发现了关键的tx.origin相关问题。
测试二
用例:《智能合约安全审计入门篇——溢出漏洞》
漏洞代码:
对?GPT?进行提问:
火币HT抢购火爆,数据惊人:火币全球通用积分Huobi(HT)抢购数据:1分40秒售罄, 1月25日第二天比首日更加激烈,其中1万元点卡套餐6秒被秒光~其次是1000元1分4秒;100,000万1分5秒;100元1分40秒。HT在1月24日上午10点推出后就引发币圈疯抢,2分26秒内售罄。[2018/1/25]
GPT-3.5(Web)answer
GPT-3.5-turbo-0301answer
GPT-4(Web)answer
区块链私募火爆 机构正在入场:近日,区块链项目私募的火热再次吸引了不少投资者的关注,而在今日,多位圈内大咖推出了门槛为500ETH的私募投资群,并表示入群者可以拿到市面上拿不到的私募额度。同时,郭宏才在微博表示有机构正在入场,网友认为,这是在花式割韭菜,不过也有人认为,这可能意味着大资金会进入场内。 ?[2018/1/2]
可以看到GPT-3.5(Web)、GPT-3.5-turbo-0301都发现了关键的Overflow漏洞,出乎意料的是GPT-4(Web)居然没有相关提示。
测试三
用例:《空手套白狼——Popsicle被黑分析》
漏洞代码:
对GPT进行提问:
GPT-3.5(Web)answer
GPT-3.5-turbo-0301answer
比特币期货上市后反应火爆 还有很多投资者难以进入市场:全球最受欢迎的加密货币的期货在CBOE首次交易中上涨了26%,引发了两次暂停交易,旨在平息市场。DV Chain首席执行官Garrett See表示,一些想要交易比特币期货的人很难进入这个市场,因为并不是所有的经理人都在最初支持它。[2017/12/12]
GPT-4(Web)answer
对比结果,我们可以看到3个版本都未发现关键的漏洞点。
代码片段的检测总结
可以看到GPT模型对简单的漏洞代码块的检测能力还是不错的,但是对稍微复杂一点的漏洞代码暂时还无法检测,并且在测试中可以看到GPT-4(Web)的整体上下文可读性很高,输出格式清晰、舒服,但是其对代码的审计能力暂时没有远超GPT-3.5(Web)、GPT-3.5-turbo-0301,甚至在部分测试中由于Transformer输出存在一定的不确定性反而导致GPT-4(Web)遗漏了一些关键问题。
对比已知漏洞的全量合约检测
为了更加契合普通项目方在合约审计中的简单操作需求,这里我们提高些难度,针对代码量大的合约进行全量导入上下文,让GPT-4模型进行审计。
用例:《千万美元被盗——DeFi平台MonoXFinance被黑分析》
整份合约分批输入,在对话最后提出检测漏洞请求
这里使用Prompt:
Hereisasoliditysmartcontract?
Contractcode
Theaboveisthecompletecode,helpmediscovervulnerabilitiesinthissmartcontract.
可以看到,GPT-4虽然在OpenAI公布的信息中其单次输入字符总数已经是当前最高,但还是会由于文本超长导致在最后提问时GPT会上下文缺失而只识别到部分内容,所以这样对大型合约而言就无法进行完整的上下文审计。
拆封整份合约,分批输入分批检测
这里使用Prompt:
对话1:
Helpmediscovervulnerabilitiesinthissoliditysmartcontract.
分段内容1
对话2:
Helpmediscovervulnerabilitiesinthissoliditysmartcontract.
分段内容2
对话3:
Helpmediscovervulnerabilitiesinthissoliditysmartcontract.
分段内容3
总结
GPT当前是否适合合约分析
优点
GPT对合约代码中基础的简单的漏洞具备部分检测能力,并且在检测出漏洞后会以很高的可读性来解释漏洞问题,这样的特性比较适合为初级合约审计工作者前期训练提供快速指导和简单答疑。
存在的问题
a.每次生成内容波动
GPT对每次对话的输出存在一定的波动,可以通过API接口参数进行调整,但是依旧不是恒定的输出,虽然这样的波动性对语言对话来说是好的方式,大大提高了对话给人的真实感。但是这对代码分析类的工作来说是一个不好的问题。因为为了覆盖AI可能告知我的多种漏洞回答,我需要多次请求同一问题并进行对比筛选,这无形中又提高了工作量,违背了AI辅助人类提高效率的基准目标。
例如这里再次运行"漏洞代码片段的检测对比测试二:
可以看到其输出结果比之前测试又多了一些额外内容。
b.?漏洞分析能力依旧有很大的提高空间
对稍微复杂的漏洞进行检测即会发现当前的训练模型不能正确的分析并找到相关关键漏洞点。
GPT辅助合约审计的可行性和潜力分析
虽然当前来看GPT对合约漏洞的分析及挖掘能力还处于相对较弱的状态,但它对普通漏洞小代码块的分析并生成报告文本的能力依旧让使用者兴奋,在可预见的未来几年伴随这GPT及其他AI模型的训练开发,相信对大型复杂合约的更快速,更智能,更全面的辅助审计一定会实现。当科技发展可指数级提高人工的效率时就会发生质变,我们非常期待AI对区块链安全的助力,我们会持续关注新AI产品对区块链安全的影响。最后可见的将来我们必将与AI在一定程度上进行融合,愿AI和区块链与你同在。
标签:GPT区块链WEBANSgpt币团队区块链通俗易懂的讲解Web 3 DevelopmentTower Defense Titans
原文来源:比推BitpushNews一季度行情即将接近尾声,比特币和以太坊的走势越来越趋同,几乎完全相关。比推终端数据显示,以太坊年初至今(YTD)上涨了50.02%?,但比特币却飙升了72.30%?,有望创下两年来最佳的季度表现.
1900/1/1 0:00:00作者:木遥,来源:作者微博你可能已经看到ChatGPT今天宣布推出插件功能的新闻了。这可能是近期一系列进展中最令人惊讶和震撼的一个.
1900/1/1 0:00:00DeFi的优势之一是任何人都可以随时随地参与其中,即任何人任何时候都有机会作为DeFi参与者获得收益,甚至获得在传统金融领域很难或不可能获得的收益.
1900/1/1 0:00:00目前SUINetwork没有正式的空投计划,但是SUINetwork已经发布了SUIToken社区访问计划,以及SUIToken的分配细节。Sui是一种基于Move语言的主要新L1公链之一。永久测试网最近上线,并完成了更新.
1900/1/1 0:00:00引言:随着中国国家发展和改革委员会牵头联合十部委共同发布的《关于整治虚拟货币“挖矿”活动的通知》与中国人民银行牵头联合十部委共同发布的《关于进一步防范和处置虚拟货币交易炒作风险的通知》的出台.
1900/1/1 0:00:00来源:美国商品期货交易委员会(CFTC);翻译:ChatGPT&金色财经2023年3月27日,美国商品期货交易委员会(CFTC)宣布,它已向美国伊利诺伊州北区地方法院提起民事诉讼.
1900/1/1 0:00:00