如何解决在 BSCScan.com 上验证合同
我在一个朋友的帮助下创建了一个加密货币(我们花了很长时间从这里和那里复制粘贴代码)并编辑合同的信息,这对我来说至关重要,我现在需要验证合同.这是我的合同地址:
0xe1c7a0d5e099a1f0c14b60b0c320423cf2f4543b
这是我在 Remix 中使用的代码:
pragma solidity >=0.8.0;
import "https://github.com/OpenZeppelin/openzeppelin-contracts/blob/master/contracts/token/ERC20/ERC20.sol";
contract HelpingArtistsAtRisk is ERC20 {
constructor(uint256 initialsupply) public ERC20 ("Helping Artists At Risk","HAAR"){
_mint(msg.sender,initialsupply);}
}
警告:源文件中未提供 SPDX 许可证标识符。在发布之前,请考虑向每个源文件添加包含“SPDX-License-Identifier:”的注释。对非开源代码使用“SPDX-License-Identifier:UNLICENSED”。请参阅 https://spdx.org 了解更多信息。 --> myc
ParserError:找不到源“https://github.com/OpenZeppelin/openzeppelin-contracts/blob/master/contracts/token/ERC20/ERC20.sol”:不支持文件导入回调 --> myc:3:1: | 3 |导入“https://github.com/OpenZeppelin/openzeppelin-contracts/blob/master/contracts/token/ERC20/ERC20.sol”
BEP-20.sol:1:1:错误:编译器版本 >=0.8.0 不满足 r semver 要求
解析器错误:预期的编译指示、导入指令或合同/接口/库/结构/枚举/常量/函数定义。 --> myc:1:1: | 1 | “SPDX-License-Identifier: UNLICENSED” | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
我只是想得到 BSCSCAN 的验证。
解决方法
从solidity 0.6.8开始,你应该为你的合同设置一个许可证头,所以你需要在文件的第一行添加:
// SPDX-License-Identifier: UNLICENSED
您可以使用 UNLICENSED 或使用预定义的许可证之一。这是列表:https://spdx.org/licenses/
有关 SPDX 许可证转移器的更多信息,请访问:https://forum.openzeppelin.com/t/solidity-0-6-8-introduces-spdx-license-identifiers/2859
这应该可以修复您的第一个警告和最后一个错误。
进行此更改后,我能够使用 remix 编译合约,但我认为所有其他错误都与编译器版本有关,您能否分享您在编译器选项中看到的版本和其他设置?
我正在使用编译器 0.8.4+commit.c7e474f2
还需要删除构造函数中的 public 关键字,编译器会忽略它。最终结果是:
// SPDX-License-Identifier: UNLICENSED
pragma solidity >=0.8.0;
import "https://github.com/OpenZeppelin/openzeppelin-contracts/blob/master/contracts/token/ERC20/ERC20.sol";
contract HelpingArtistsAtRisk is ERC20 {
constructor(uint256 initialsupply) ERC20 ("Helping Artists At Risk","HAAR"){
_mint(msg.sender,initialsupply);}
}
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。