验证合约的三种方式

验证合约的三种方式,第1张

方式一:

使用truffle插件: https://github.com/rkalis/truffle-plugin-verify

truffle run verify 合约名称@合约地址 --network 网络名称 --debug

注意:需要开启VPN,然后给CMD也设置代理,否则CMD无法访问外网会验证失败 (每次新开CMD都要执行)

//cmd设置代理
set HTTP_PROXY=http://127.0.0.1:port
set HTTPS_PROXY=http://127.0.0.1:port

 方式二:

在etherscan上手动上传

1、合约文件如果有导入的外部合约,需要整合成一个文件(truffle插件自动生成)truffle-flattener

生成的可能要去掉多余的License描述,如有多个的话

truffle-flattener x.sol > xx.sol

2、选择部署时正确的编译版本、是否优化

部署使用0.8.1,代码中是0.8.0,在上传时选择任何一个都验证失败,最后选择的是最新的0.8.4版本直接验证成功(就很诡异)

3、如果是有构造函数,需要填写ABI-encode,也可以根据ABI JSON自动生成。,没有就不需要填写

ABI Encoding Service Online for Solidity Smart Contracts by HashEx

方式三:

remix上的etherscan插件

其实跟truffle插件差不多,也是用API Key去请求,前提是你的合约在remix上编译的就比较方便,否则不建议使用。

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/zaji/943319.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-05-18
下一篇 2022-05-18

发表评论

登录后才能评论

评论列表(0条)

保存