NFT 智能合约中的元数据(Metadata)

简介: 如何在智能合约中添加和存储元数据(Metadata)?

如何在智能合约中添加和存储元数据(Metadata)?

元数据(Metadata)是所有 NFT 合约的重要组成部分,每个代币都有数据可供 OpenSea 等市场检索并用于显示 NFT 的内容,因此智能合约元数据(Metadata)是一个需要了解的重要信息。

那么如何存储它,甚至将它存储在哪里?以及如何在 NFT 中实现元数据存储(Metadata)?

什么是元数据(Metadata)文件?

NFT 合约的元数据(Metadata)文件是存储在区块链之外某处的 JSON 文件。通过一些技巧,可以在链上执行此操作,也可以在 IPFS 上执行此操作,或者在自己构建的服务器上执行,可以考虑使用 CDN。

这些文件可能以它们存储的令牌数据命名 tokenId。像 OpenSea,它们的内容如下:

{
  "description": "Friendly OpenSea Creature that enjoys long swims in the ocean.", 
  "image": "https://storage.googleapis.com/opensea-prod.appspot.com/puffs/9.png", 
  "name": "Dave Starbelly",
  "attributes": [
    {
      "trait_type": "Base", 
      "value": "Starfish"
    }, 
    {
      "trait_type": "Eyes", 
      "value": "Big"
    }
  ], 
}

如下述代码所示有描述、图像链接、名称和一些可选属性。这是一种相当简单的 JSON 格式,可以在此处了解有关元数据标准的更多信息。接下来看看如何将这些数据从 IPFS 或 CDN 应用到智能合约中。

ERC721 TokenURI 和 BaseURI

ERC721 是需要在智能合约中实施才能被称为 NFT 的标准。它实现了 IERC721,即 ERC721 标准的接口。它的功能不多,但即便如此,大多数收藏品都从OpenZeppelin导入智能合约,避免重复造轮子。

OpenZeppelinERC721 合约有一些不错的额外功能和一些可选扩展。但基础 ERC721 智能合约有两个值得注意的功能,即存储元数据、tokenURI 以及 _baseURI

_baseURI 整个 tokenURI 的基础。例如,如果有 10k 个令牌的集合,可能已将元数据保存在 CDN 或 IPFS 上的文件夹中。这意味着每个令牌的整个 URI 都是完全相同的,除了最后一部分,通常是 tokenId

因此,如果 _baseURIipfs://your_folder_hash/,并且特定令牌的 tokenId1234,那么完整的 tokenURI 将是 ipfs://your_folder_hash/1234

但是,需要自己实际实现 _baseURI 函数。如果它什么都不返回,则 tokenURI 函数将返回一个空字符串。

string private _baseUri;
function setBaseURI(string calldata baseUri) external onlyOwner() {
    _baseUri = baseUri;
}
function _baseURI() internal view override returns (string memory) {
    return _baseUri;
}

在智能合约中,添加一个包含 _baseURI 的字符串类型变量(公共或私有)。可以通过从任何地方调用 setBaseURI() 来设置这个变量。当有人调用 tokenURI() 时,智能合约会检索它,因为这会自动将 tokenId 附加到 OpenZeppelinERC721 智能合约中的 baseURI

ERC721URIStorage

它的一个扩展是 ERC721URIStorage,它允许为每个令牌设置不同的 tokenURI。如果为可能在 IPFSCDN 中不共享同一文件夹的 1/1 艺术品创建智能合约,这可能会很有用,增加了以下功能。

  • tokenURI(tokenId)
  • _setTokenURI(tokenId, _tokenURI)

铸造时,调用 _setTokenURI() 为该新令牌设置 tokenURI,它还为这个新功能覆盖了 tokenURI 函数。

总结

元数据(Metadata)是 NFT 的重要组成部分。它存储图像和其他基本数据,文章介绍了如何使用 OpenZeppelins ERC721 合约和 ERC721URIStorage 的小扩展来实现它。


相关文章
|
6月前
|
测试技术 API 区块链
Hyperledger fabric部署链码(三)批准链码定义
fabric部署chaincode-go(智能合约)系列之三
|
JSON Java 区块链
在Xuper链上部署Java语言智能合约和分析存证合约的实现逻辑(3)
在Xuper链上部署Java语言智能合约和分析存证合约的实现逻辑(3)
211 0
在Xuper链上部署Java语言智能合约和分析存证合约的实现逻辑(3)
|
Java 区块链 开发工具
在Xuper链上部署Java语言智能合约和分析存证合约的实现逻辑(1)
在Xuper链上部署Java语言智能合约和分析存证合约的实现逻辑(1)
316 0
在Xuper链上部署Java语言智能合约和分析存证合约的实现逻辑(1)
|
Java Go 区块链
在Xuper链上部署Java语言智能合约和分析存证合约的实现逻辑(2)
在Xuper链上部署Java语言智能合约和分析存证合约的实现逻辑(2)
213 0
|
Java Go 区块链
在百度超级链Xuper上部署智能合约并实现存证功能(3)
在百度超级链Xuper上部署智能合约并实现存证功能(3)
465 0
在百度超级链Xuper上部署智能合约并实现存证功能(3)
|
Shell Go 区块链
在百度超级链Xuper上部署智能合约并实现存证功能(1)
在百度超级链Xuper上部署智能合约并实现存证功能(1)
339 0
在百度超级链Xuper上部署智能合约并实现存证功能(1)
|
区块链
在百度超级链Xuper上部署智能合约并实现存证功能(2)
在百度超级链Xuper上部署智能合约并实现存证功能(2)
242 0
在百度超级链Xuper上部署智能合约并实现存证功能(2)
|
区块链
Hyperledger Fabric 2.x 动态更新智能合约
在上一篇文章中分享了智能合约的安装与使用,如果业务有变更代码需要修改怎么办呢?本文分享如何对已安装的合约进行版本更新。
222 0
Hyperledger Fabric 2.x 动态更新智能合约
|
Java 区块链 开发工具
Hyperledger Fabric 2.x 自定义智能合约
本文分享如何使用 Java 语言开发智能合约,以及合约的安装与使用。
474 0
Hyperledger Fabric 2.x 自定义智能合约
|
区块链 消息中间件 Kafka
fabric区块链configtxgen配置文件解析
configtx.yaml是Hyperledger Fabric区块链网络运维工具configtxgen用于生成通道创世块或通道交易的配置文件,configtx.yaml的内容直接决定了所生成的创世区块的内容。
1435 0