提示:文章写完后,目录可以自动生成,如何生成可参考右边的帮助文档
目录
前言
一、NFT 非同质化(Non-Fungible)是什么?
二、什么是erc721
三 、如何实现
1.使用ipfs
2.读入数据
3.编写solidity代码
总结
最近元宇宙的概念特别火,相关的话题就和nft有关,那么如何实现呢
提示:以下是本篇文章正文内容,下面案例可供参考
同质化是指相同或可互换的意思。 例如,以太坊代币、特定代币类的所有币,都具有相同的价值。 Cardano代币也是如此。 同质化代币可1:1互换。
而NFT是独一无二的,每个人都是不同的。 每一个代币都有独特的特点和价值。 可以成为NFT的东西类型有收藏卡、艺术品、飞机票等。 它们之间都有明显的区别,不能互换。 将非同质化代币(NFT)视为稀有的收藏品;每个代币都有独特的特征,不寻常的属性,大多数时候,它利用元数据表示。
ERC是以太坊建议请求(Ethereum Request for Comment)的缩写,721是提案编号。 ERC是以太坊生态系统中的应用级标准,它们可以是代币的智能合约标准,如ERC-20,ERC的作者负责与以太坊社区建立共识,一旦提案被社区审核通过,就会成为标准。 你可以跟踪最近的ERC提案这里。 ERC-721的创建是为了提出在智能合约内跟踪和转移NFT的功能。
ERC-721是一个开放的标准,它描述了如何在EVM(以太坊虚拟机)兼容的区块链上构建非同质化代币;它是非同质化代币的标准接口;这是一套规则,使其易于与NFT 交互。 NFT不仅是ERC-721 代币,还可以是ERC-1155代币。
以下是ERC-721标准中定义的一组函数和事件:
ERC-721定义了一些符合ERC-20的函数。 这使得现有钱包更容易显示简单的代币信息:
在写NFT合约之前,我们需要托管好NFT所对应的艺术作品,并创建一个元数据文件;为此,我们将使用IPFS--一个点对点文件存储和共享的分布式系统。 按照IPFS文档中的安装指南下载并安装基于你的操作系统的IPFS CLI。
以下是托管图像和元数据文件的步骤:
步骤1:创建IPFS repo。 在终端窗口中输入以下内容来初始化IPFS repo
$ ipfs init
步骤2:启动IPFS守护进程。 打开一个单独的终端窗口,输入以下内容:
$ ipfs daemon
步骤3:添加图像到IPFS , 进入第一个终端窗口,将图像添加到IPFS中(这里是art.png)。
$ ipfs add art.png
当然在视图模式下也差不多,比较简单就不在累述了。
复制从Qm开始的哈希值,并添加 https://ipfs.io/ipfs/
前缀,它必须看起来像这样https://ipfs.io/ipfs/QmdrswwrbcfPeknN2BRLVmyWbWRsKSC3vSNhV9Gkvhk1mL。
步骤4: 向IPFS添加JSON文件。 创建一个JSON文件nft.json,并将其保存在与图像相同的目录中。 JSON文件格式:
{
"name": "NFT Art",
"description": "This image shows the true nature of NFT.",
"image": "https://ipfs.io/ipfs/QmZzBdKF7sQX1Q49CQGmreuZHxt9sVB3hTc3TTXYcVZ7jC",
}
现在添加JSON文件:
$ ipfs add nft.json
复制从Qm开始的哈希值,并添加 https://ipfs.io/ipfs/
前缀,它必须看起来像这样https://ipfs.io/ipfs/QmWKqwMJQHSfpfRFGUVGPFFtkBJ5WkFzhjQpruhSLtLWXB, 保存这个网址。 我们需要这个来铸造NFT。
为了方便和安全,我们将使用0xcert/ethereum-erc721合约来创建我们的NFT合约。 有了0xcert/ethereum-erc721,我们不需要写整个ERC-721接口。 相反,我们可以导入库合约并使用它的函数。 前往以太坊 Remix IDE,制作一个新的Solidity文件,例如 nft.sol, 将以下代码粘贴到Solidity 文件中。
// SPDX-License-Identifier: MIT
pragma solidity 0.8.0;
import "https://github.com/0xcert/ethereum-erc721/src/contracts/tokens/nf-token-metadata.sol";
import "https://github.com/0xcert/ethereum-erc721/src/contracts/ownership/ownable.sol";
contract newNFT is NFTokenMetadata, Ownable {
constructor() {
nftName = "Synth NFT";
nftSymbol = "SYN";
}
function mint(address _to, uint256 _tokenId, string calldata _uri) external onlyOwner {
super._mint(_to, _tokenId);
super._setTokenUri(_tokenId, _uri);
}
}
如果不行可以可以在 github复制代码使用
以下是代码的解释:
第1行: 指定SPDX许可证类型,这是在Solidity ^0.6.8之后增加的。 每当智能合约的源代码向公众开放时,这些许可证可以帮助解决/避免版权问题。 如果你不想指定任何许可证类型,你可以使用一个特殊的值UNLICENSED,或者直接跳过整个注释(它不会导致错误,只是一个警告)。
第2行: 声明 Solidity 版本。
第4-5行:导入0xcert/ethereum-erc721合约。
第7行: 合约命名为newNFT,它继承了NFTokenMetadata和Ownable合约。
第9-12行: 初始化构造函数并设置名称及代币符号。
第14行:声明函数mint有三个参数,类型为地址的变量_to,存储NFT代币接收者的地址,类型为uint256的变量_tokenId,将保存代币id,类型为字符串的变量_uri,将存储JSON文件的URI。 将mint声明为外部函数,可以从其他智能合约和当前合约之外访问。
第15行:使用接收方的地址和代币ID来铸造代币。
第16行:使用代币id和JSON文件的URI设置代币URI。
编译智能合约,并使用Injected Web3进行部署(编译合约前一定要在Metamask上选择Ropsten testnet)。 批准来metamask的交易。
如果你在部署前收到一条错误消息:此合约可能是抽象的
,请确保在合约选项卡下选择适当的合约。在Metamask中确认交易。
现在进入Remix中的 Deployed Contracts(部署的合约)
部分,展开部署的合约。 你会看到一堆函数/方法。 展开mint函数并添加以下参数:
在_to中添加你的Ropsten地址。
在 _tokenid 中输入任何数字值 (建议为1,因为它是第一个)。
在_uri字段中,添加上一节获得的JSON文件的URI。
点击交易,并从metamask确认交易。 (需要你已经有了Ropsten链上的ETH)
你可以通过输入我们之前提到的token id来查看其他细节,如名称、符号、所有者或tokenuri。
兼容ERC-721标准的加密收藏品已经非常流行,并在最近几个月向大规模采用的方向发展。 本指南将涵盖使用0xcert/ethereum-erc721智能合约库创建和部署我们自己的ERC-721(NFT)。
仅供学习使用
转载于原文: How to create and deploy an ERC-721 (NFT) explained - step-by-step beginners guides | QuickNode
参考于如何创建和部署ERC-721(NFT)? | 登链社区 | 深入浅出区块链技术