原文链接:https://blog.chain.link/build-deploy-and-sell-your-own-dynamic-nft-zh/
NFT是只有在区块链领域里才存在的工具,有着广泛的应用和机遇。ERC721代币标准可以构建收藏品、独立代币、票据、游戏等多种应用,对于那些想要参与构建的开发者来说,一个动态和随机的NFT是一个很好的开始。但我们现在可以用它做什么?展示你新铸造的随机化或动态角色,是不是很赞?
我们也是这样认为的。在本教程中,我们将引导您完成所有步骤,将您自己的动态或随机化NFT部署到OpenSea市场。下面是一个例子,是我们希望达到的效果。
图片来自OpenSea
让我们来学习如何制作类似上面的东西吧!
NFT快速复习
ERC721(也被称为NFTs)定义了一个框架,用于制作代币的框架,这些代币是独一无二的,并且彼此之间是不同的(因此被称为非同质化),而流行的ERC20标准则定义了 “同质化”的代币,这意味着代币都是可互换的,并且每个代币具有相同的价值。我们将更深入地探讨如何构建这些,以及社区如何跨平台代表它们。你也可以在OpenSea NFT圣经中阅读更多内容。
如果你还没有查看上一篇关于在NFT中获取随机数的文章,请务必去回顾一下!开发者页面中有着各种智能合约和区块链工程教学的教程、指南和攻略。
什么是元数据
在上一篇博客中,我们学习了如何构建随机NFT。现在,我们将使用ERC721标准的另一个重要部分:*元数据*,将其提升到一个新的水平。
所有的NFT都有所谓的元数据。你可以在原始的[ERC/EIP 721提案](ERC/EIP 721提案)中读到这一点。社区发现,在Ethereum上存储图像真的很费力,而且成本很高。如果你想存储一张8×8的图片,存储这么多数据是的费用还可以接受,但如果你想要一张分辨率不错的图片,就需要花费巨额的费用。
数据存储的成本约为每Kb64万gas。假设当前的gas价格为50 Gwei也就是0.000000050 ETH, 1 ETH现价600美元,将花费20美元。
花费20美元,将这样一个图形添加到区块链中,并没有让NFT的创造者们真正兴奋起来。
我们意识到Ethereum 2.0将解决很多这些令人头疼的扩展问题(同时也祝贺ETH2.0成功启动),但目前社区需要一个标准来帮助解决这个问题。元数据就是这个问题的答案。
元数据为链外存储的tokenId提供描述性信息。这些都是简单的API,链外UI调用这些API来收集有关token的所有信息。每个tokenId都有一个特定的tokenURI,定义了这个API调用,它返回一个JSON对象,看起来像这样:
{
"name": "You NFT token name",
"description": "Something Cool here",
"image": "https://ipfs.io/ipfs/QmTgqnhFBMkfT9s8PHKcdXBn1f5bG3Q5hmBaR4U6hoTvb1?filename=Chainlink_Elf.png",
"attributes": [. . .]
}
元数据有四个不同的key:
-
`name`,定义了tokenIds的可读名称
-
`description`,其中提供了一些关于token的背景信息
-
`image`是图像的另一个URI
-
`attributes`是token的统计数据
如果您的NFT与其他NFT进行交互,确保tokenURI上的属性(attributes)与您的NFT智能合约的属性(attributes)相匹配,这一点非常重要,否则当战斗或互动没有达到预期时,您可能会感到困惑!
为`tokenURI`分配出tokenIds之后,NFT市场就能够显示你的token,让你展示你的创造力。你可以在Rinkeby testnet的OpenSea市场上看到我们使用更新后的《龙与地下城》随机NFT代码仓库创建的一个NFT。这种市场有很多,比如Mintable、Rarible
链上和链下元数据
你可以一直将所有的元数据存储在链上(事实上,这是与代币进行交互的唯一方式),但很多NFT市场不知道如何读取链上元数据_现在。_所以目前来说,使用链下元数据来可视化你的代币,同时拥有所有的链上元数据是最理想的,这样你的代币就可以互相交互。
名称、描述和属性很容易在链上存储,但图像才是难点。另外,我们在哪里存储tokenURI的API?很多人选择运行服务器来托管信息,这很好,但这是一个中心化的用于可视化token的地方。如果我们能把图片存储在链上,这样就不会宕机或被黑客攻击,是一个更好的选择。在上面的例子中,他们的图片使用的是指向IPFS的URL,这是一种常用地存储图片的方式。
IPFS是InterPlanetary File System(星际文件系统)的缩写,是一种点对点的超媒体协议,旨在使网络更快、更安全、更开放。它允许任何人上传一个文件,并且该文件是经过哈希校验的,所以如果文件发生改变,它的哈希值也会改变。这对于存储图片来说是非常理想的,因为这意味着每次图片更新时,链上的哈希/tokenURI也要改变,同时这意味着我们可以拥有元数据的历史记录。将图像添加到IPFS上也非常简单,而且不需要运行服务器。
现在我们知道了要做什么,下面让我们来构建和部署吧!你部署了你的NFT代币和市场之后,一个代币将看起来像这样:
OpenSea上的Chainlink骑士
`levels`部分是代币的随机统计数据的地方!
如何部署你的动态NFT市场
再次强调一下,我们使用最新版本的Dungeons&Dragons代码仓库,在readme中也有说明。
下面我们要做:
-
使用Chainlink VRF构建一个可验证的随机D&D角色
-
使用IPFS添加一个tokenURI
-
将随机NFT添加到OpenSea市场中
请记住,你可以改变仓库,使其适用于动态NFTs。你可以很容易地把VRF换成Chainlink Price Feeds或Chainlink API。
这个仓库目前只适用于Rinkeby,所以请务必切换到到Rinkeby网络!我们会从头开始讲解,如果你没有读过上一篇文章也不用担心。
你需要在你的钱包里有Rinkeby Testnet ETH和Rinkeby Testnet LINK才能继续。
配置环境变量
配置`MNEMONIC`和一个rinkeby `RINKEBY_RPC_URL`环境变量。你的`MNEMONIC`是你的钱包的种子短语。你可以从节点提供者服务中找到一个`RINKEBY_RPC_URL`,比如Infura。
然后,将它们设置在`bash_profile`文件中,或者像这样将它们导出到你的终端:
exportMNEMONIC=
export RINKEBY_RPC_URL=
接下来你需要这样做:
克隆仓库并部署
gitclonehttps://github.com/PatrickAlphaC/dungeons-and-dragons-nftcd
dungeons-and-dragons-nft
npminstall
truffle migrate --reset --network rinkeby
上面的命令部署你的D&D NFT!
创建角色
可以通过以下命令来尝试:
truffleexecscripts/fund-contract.js--networkrinkeby
truffleexecscripts/generate-character.js--networkrinkeby
truffle exec scripts/get-character.js --network rinkeby
上面的命令可以通过随机数据创建一个新的角色!
根据你部署的频率,你可以通过改变`get-character.js`中的`dnd.getCharacterOverView(1)`命令来选择哪个角色,将`0`换成你喜欢的任何角色的tokenId。
以上命令提供了NFT的概览。因为调用返回的是大数字(big numbers),所以会看到`BN`,你可以把它们转为整型来查看它们是什么。或者你可以更进一步…
在Etherscan查看
你可以免费获得一个Etherscan API密钥,并与链上的NFT进行交互。然后将`ETHERSCAN_API_KEY`设置为环境变量。
npminstalltruffle-plugin-verify
truffle run verify DungeonsAndDragonsCharacter --network rinkeby --license MIT
这样就可以验证并发布你的合约,可以去它给你的Etherscan的`Read Contract`部分查看。
或者可以使用oneclickdapp,只需添加合约地址和ABI。可以在`build/contracts`文件夹中找到ABI。注意,ABI不是整个文件,只是写着`ABI`的部分。
部署到OpenSea
创建好NFT后,我们需要给它们一个`tokenURI`。TokenURI是向世界展示NFTs数据的标准。可以让我们更容易存储图片等内容,不必浪费气力在链上存储它们。
`TokenURI`代表一个URL或其他唯一的标识符,它是一个带有一些参数的`.json`文件。
{
"name":"Nameforit",
"description":"Anythingyouwant",
"image":"https://ipfs.io/ipfs/HASH_HERE?file.png",
"attributes":[...]
}
下载IPFS和IPFS Companion
现在,我们将把这些图像和元数据存储在IPFS中。你需要
-
IPFS
-
IPFS companion
-
Pinata
IPFS companion让我们可以在Brave或Chrome等浏览器中原生查看IPFS数据。而Pinata可以让我们在节点宕机时也能保持IPFS文件的正常运行(暂时不用担心这个问题)。
如果你在浏览器中点击这个链接,你就会知道IPFS companion运行正常:
https://ipfs.io/ipfs/QmTgqnhFBMkfT9s8PHKcdXBn1f5bG3Q5hmBaR4U6hoTvb1?filename=Chainlink_Elf.png
就会展示下面的图像:
Chainlink精灵
添加图像到IPFS
IPFS节点建立起来之后,就可以开始向它添加文件了。首先要上传我们NFT的图像。前往IPFS安装的 “files”部分。
IPFS 文件
这个D&D角色是什么样子的?将它添加到你的IPFS节点,然后 “Pin “它。现在,你可以随意pin一个空白的图片,或者随便任何东西。
添加元数据文件到IPFS
然后需要将元数据JSON对象添加到IPFS中。需要从部署的代币中获取名称和属性。我们在`create-metadata.js`脚本中为做了一些工作。只需运行
truffle exec scripts/create-metadata.js --network rinkeby
元数据会显示在`metadata`文件夹中。它现在只需要图片的URL!元数据是我们使用Chainlink VRF创建的随机数和统计数据。现在我们得到我们创建的图片的CID,并将其添加到元数据JSON文件中,然后将该文件也添加到IPFS中,并将其pin住!它看起来会像这样:
Chainlink精灵JSON
Pinata
如果IPFS节点宕机了,或者关闭了计算机,我们将无法拉取元数据,所以我们需要一种方法来保持它们pin的状态,并让其他节点托管数据。这就是Pinata的作用。别担心,它是免费的!作用是在我们的IPFS节点停机时帮我们维护数据。复制图像和JSON元数据文件的CID,并将其添加到Pinata账户中。这需要几秒钟的时间来注册。
复制CID
这个元数据 json 文件就是 `tokenURI`,所以我们用给图片NFT的 tokenId 来修改 `set-token-uri.js`,并添加 ipfs tokenURI。
然后我们用
truffle exec scripts/set-token-uri.js --network rinkeby
现在就可以得到NFT的地址,然后到OpenSea testnet市场去看看我们做的是否正确。如果做得正确,它将看起来像这样。我们要先在OpenSea注册一个账户。
这里是添加你的testnet NFT合约在opensea上查看的链接。然后,就可以开始出售你的NFT了。