NFT (Non-Fungible Token),这2年又火了起来,早在18年已经火过一波。
本文只从写代码实现NFT的技术方案
层面去介绍 NFT,不从其金融意义、案例,等层面去谈,因为这类内容可以随便在浏览器搜索到,而我接下来要谈的内容,浅层搜索下,数量不多。
制作id,这是把物质制作成 NFT 的第一步。物质有哪些?一段文字、一张图片,一件衣服等,夸张的说,现实世界的物质,无论是虚拟的(游戏装备)或实质物质,都可以被通证化。
通过第三方技术手段
获取物质的唯一标志性中间产物。
因此制作 NFT 第一步,广义于下面等式:
最简单的例子就是哈希函数,不考虑哈希碰撞,它就可以根据不同的内容输出不同的哈希值。思维在这里不要局限于哈希函数。
这里用图片代表一系列的文件类数据。
这里用衣服来代表一系列的实际物质。如果获取它们的唯一id呢?做法可以放飞思维去思考,比如可以:
第一步中获取了物质的id,现在要把它们通证化。切记一点:目前公认的 NFT 都是基于区块链公链的,那么以后是不是会一直这样呢?不一定,说不准出来了新的共识。
通证化的流程如下:
智能合约
等系统组件的技术栈,这一点很核心;NFT 智能合约可以基于不同的公链开发,它不局限于任何一条公链。不同公链的智能合约方案实现也不同,下面以 以太坊 公链举例说明。
在以太坊上面,开发 NFT 智能合约,已经有很多标准,比如 ERC-721 \1155 \998,各有各的特点,但它们的特点是在基础属性上拓展而来的。(各标准文档: https://eips.ethereum.org/EIPS/eip-721)
如果选择 ERC-721 标准开发 NFT 智能合约,在元数据存储部分,就有 tokenUrl 这项,它相当于物质的唯一id,像下面的样子, _tokenURIs
存储的就是通证当前计数id与其对应的 tokenUrl,这里的tokenUrl 是字符串格式,一般是文件url,存储在 IPFS 或其他服务上面的文件的链接,但不局限于链接,也可以是其它的内容。
// 伪代码
contract MyERC721 is IERC721Metadata, ... {
...
mapping(uint256 => address) private _tokenOwner;
mapping(uint256 => string) private _tokenURIs;
uint256 public tokenCounter; // 计数,当前总的 NFT 的数量,累增
constructor () public ERC721 ("name", "symbol"){
tokenCounter = 0;
}
// 外部调用方,调用这个函数,传参数:tokenURI 即物质的id,tokenURI 唯一
function createNFT(string memory tokenURI) public returns (uint256) {
uint256 tokenId = tokenCounter;
_mint(msg.sender, tokenId); // 将交易发送者和当前的 tokenId 绑定
_setTokenURI(tokenId, tokenURI); // tokenId 映射到 tokenUrl
tokenCounter = tokenCounter + 1; // 累加
return tokenId;
}
// _exists 函数判断 tokenId 是否存在,_tokenOwner[tokenId]
// 根据 id 读取对应的 url
function tokenURI(uint256 tokenId) external view returns (string memory) {
require(_exists(tokenId));
return _tokenURIs[tokenId];
}
// 根据 tokenId 和 url 建立 map 数据关系
function _setTokenURI(uint256 tokenId, string memory uri) internal {
require(_exists(tokenId)); // _exists
_tokenURIs[tokenId] = uri;
}
... // 省略系列接口,包含读接口
}
上面的 tokenUrl 是标准要求的存储数据项。整个合约具备下面约束功能:
一般来说,我们常规的 NFT 有一个和数据建立关系的项就足够了,但并不局限于此,合约在实现了标准要求的接口后,完全可以自己添加自定义数据项及其读写函数。
所谓展示,就是对 NFT 的数据进行读取再展示。一般的流程如下:
比如将图片 NFT 展示出。(借助上面的 721 合约标准和 IPFS 结合为例)
修改是一项 NFT 智能合约的拓展功能,可有可无,具体是怎样的方式,完全看需求的实现。比如:
出售 NFT
、拍卖 NFT
等操作....目前 NFT,非同质化通证。本质是想借助区块链的属性来标示一种资产的所有权证明。
比如曾拍卖出6000多万美金的数字作品(图片)《Everydays: The First 5000 Days》,中标者能获得原图 和 该图的 NFT。这两样东西,一样是实质的作品,一样是它的所有权者的证明。
我们假设下,如果持有某作品的人,是一位匿名者A,过了多年后,该作品本身不小心被盗并被找回。那么如何证明 A 是真正的拥有者,此时 A 只需要展示他对该作品的 NFT 拥有权,就可以证明。
那么 NFT 是不是类似于我们现实中的证书?不全是,分两点:
现在已经有很多的第三方的 NFT 制作与发布平台。比如 opensea、rarible 等,这些平台自己实现了 NFT 的智能合约 和 NFT 展示应用(介质应用---网站),方便大众 0 代码基础体会 NFT。但也有一些门槛,需要具备钱包和发交易的油费。