验证合约的三种方式

方式一:

使用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上编译的就比较方便,否则不建议使用。

本图文内容来源于网友网络收集整理提供,作为学习参考使用,版权属于原作者。
THE END
分享
二维码
< <上一篇
 

)">
下一篇>>