当然,如果我们想将合约部署到以太坊的实际网络上,我们只需切换网络并连接我们的浏览器插件钱包即可。
在这份ERC721代码中,我们实现的功能是任何人都可以调用合约的mint方法铸造自己的NFT,每个NFT的id都是唯一的。接下来,我们将仔细分析和解释源代码。
ERC721.sol
// SPDX-License-Identifier: MIT pragma solidity ^0.8.12;
import "@openzeppelin/contracts/token/ERC721/extensions/ERC721Enumerable.sol"; import "@openzeppelin/contracts/access/Ownable.sol"; import "@openzeppelin/contracts/utils/Counters.sol";
contract MyNFT is ERC721Enumerable, Ownable { using Counters for Counters.Counter; using Strings for uint256;
Counters.Counter private _tokenIdTracker;
event Mint(address indexed from, address indexed to, uint256 indexed tokenId);
uint256 private _currentTokenId = 0; string private constant _baseTokenURI = "https://ipfs.io/ipfs/QmXgMRpwoEtuhksEJ7LD9ySLzAvAM5tqs1q6rGZ38Qg1Kf/"; string public baseExtension = ".json";
constructor(string memory name, string memory symbol) ERC721(name, symbol) { require(bytes(name).length != 0 && bytes(symbol).length != 0, "name and symbol can't be empty"); }
function tokenURI(uint256 tokenId) public view override returns (string memory) { return string(abi.encodePacked(_baseTokenURI, tokenId.toString(), baseExtension)); }
function mint() external { uint256 tokenId = _tokenIdTracker.current() + 1; _mint(msg.sender, tokenId); _tokenIdTracker.increment(); emit Mint(address(0), msg.sender, tokenId); } } 导入"@openzeppelin/contracts/token/ERC721/extensions/ERC721Enumerable.sol"; 导入"@openzeppelin/contracts/access/Ownable.sol"; 导入"@openzeppelin/contracts/utils/Counters.sol"; 发行代币需要遵守相应的EIP协议,之前的ERC20代币遵循的是EIP20协议。OpenZeppelin是一个用于开发安全智能合约的库,它的代码经过社区审核并且有很强的社区支持,实现了标准代币接口,因此我们可以放心地使用import命令将其导入到我们的代码中。因此,在这里,我们与ERC20代码类似,也导入了其代码接口文件。 contract MyNFT is ERC721Enumerable, Ownable {} 使用is将我们需要用到的文件方法继承到主合约中,这样我们就可以使用来自继承合约的所有方法。 using Counters for Counters.Counter; using Strings for uint256; Counters.Counter private _tokenIdTracker; 由于Counter.sol是一个库合约,所以我们需要使用using命令来使用这个库合约。具体的使用方式是将库函数(来自库A)附加到任何类型(B)。 在下面的代码中,我们将使用Counters库来将uint类型的tokenId转换成string类型,所以我们还需要使用Strings库的方法。 _tokenIdTracker变量直接使用库合约Counters的方法来声明其类型。 event Mint(address indexed from, address indexed to, uint256 indexed tokenId); 我们声明了一个Mint事件,在执行mint方法时,可以返回具体的ID。