方式一:
使用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插件文章来源:https://www.toymoban.com/news/detail-421634.html
其实跟truffle插件差不多,也是用API Key去请求,前提是你的合约在remix上编译的就比较方便,否则不建议使用。文章来源地址https://www.toymoban.com/news/detail-421634.html
到了这里,关于验证合约的三种方式的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!