查看原文
其他

动态NFT的构建、部署和出售

Chainlink Chainlink预言机 2022-06-25


原文链接: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中也有说明。


下面我们要做:


  1. 使用Chainlink VRF构建一个可验证的随机D&D角色

  2. 使用IPFS添加一个tokenURI

  3. 将随机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`文件中,或者像这样将它们导出到你的终端:


export MNEMONIC='cat dog frog....'export RINKEBY_RPC_URL='www.infura.io/asdfadsfafdadf'


接下来你需要这样做:


克隆仓库并部署


git clone https://github.com/PatrickAlphaC/dungeons-and-dragons-nftcd dungeons-and-dragons-nftnpm installtruffle migrate --reset --network rinkeby


上面的命令部署你的D&D NFT!


创建角色


可以通过以下命令来尝试:


truffle exec scripts/fund-contract.js --network rinkebytruffle exec scripts/generate-character.js --network rinkebytruffle 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`设置为环境变量。


npm install truffle-plugin-verifytruffle 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": "Name for it ","description": "Anything you want","image": "https://ipfs.io/ipfs/HASH_HERE?file.png","attributes": [...]}


下载IPFS和IPFS Companion


现在,我们将把这些图像和元数据存储在IPFS中。你需要


  1. IPFS

  2. IPFS companion

  3. 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了。


下一步


我们应该都准备好了!上面涵盖了很多信息,所以如果你有任何问题,一定要联系我们的Discord。智能合约和Chainlink工程师拥有庞大的社区,很多优秀的人正聚集在一起,将NFT和智能合约推向聚光灯下,所以Discord也是一个认识其他朋友的好地方。你还想看看Chainlink Builders计划,在那里你可以通过使用Chainlink构建赢得一些很酷的奖品!


和往常一样,一定要访问开发文档,你也可以订阅Chainlink Newsletter来了解Chainlink的最新动态。


如果你在这里学到了新的东西,想展示你所开发的东西,或者为一些演示仓库开发了前端,欢迎在Twitter、Discord或Reddit上分享,并在你的仓库上加上#chainlink的标签。


Chainlink 2.0白皮书中文版已于日前发布,想要了解更多关于Chainlink 2.0的内容细节,请扫描下方二维码▼


END


▲获取Chainlink官方最新资讯

加入 Chainlink官方社区▼


Chainlink 官方渠道
QQ群: 6135525 

微博:  https://weibo.com/chainlinkofficial
知乎:https://www.zhihu.com/people/chainlink
SegmentFault:https://segmentfault.com/u/chainlink
币乎:  https://bihu.com/people/1869894547
GitHub:  https://github.com/smartcontractkit/chainlink
Discord:   https://discord.gg/aSK4zew
Twitter:  https://twitter.com/chainlink
中文 Twitter: https://twitter.com/ChainlinkChina
Telegram:  https://t.me/chainlinkofficial
合作联系:  china@smartcontract.com

点击“阅读原文” 进入 Chainlink中文官网

您可能也对以下帖子感兴趣

文章有问题?点此查看未经处理的缓存