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 的小扩展来实现它。


相关实践学习
Serverless极速搭建Hexo博客
本场景介绍如何使用阿里云函数计算服务命令行工具快速搭建一个Hexo博客。
相关文章
|
6月前
如何修改NFT的元数据
如何修改NFT的元数据
677 18
|
6月前
|
存储 Java API
java对接IPFS系统-以nft.storage为列
java对接IPFS系统-以nft.storage为列
640 3
|
安全 区块链
基于BSC链的去中心化金融(DeFi)平台PtahDAO合约开发部署示例
基于BSC链的去中心化金融(DeFi)平台PtahDAO合约开发部署示例
|
JavaScript 前端开发 IDE
【Web3 探索】如何高效地获取 NFT 元数据
获取 NFT 元数据对于理解 NFT 的属性以及确保其真实性和所有权至关重要。通过使用 Chainbase 平台及其 API,您可以获取特定 NFT 的详细元数据,使市场、收藏家和爱好者能够高效地探索和与 NFT 进行交互。
252 0
|
存储 安全 架构师
区块链101:Ethereum如何扩展
区块链101:Ethereum如何扩展
|
SQL 存储 数据挖掘
区块链数据探索:Bitcoin公链数据ETL
Bitcoin 公链可以理解为是一个公共的数据库,里面存储的是Bitcoin发布至今的所有转账记录,并且任何人只要接入到其网络中都可以获取,并不需要任何交易、挖矿、持币等相关操作。 本文主要主题的是将原始的Bitcoin公链数据进行清洗规整,写入到阿里云SLS,然后做一些有趣的数据处理,比如实现简洁的区块链浏览器、数据分析、交易链路追踪等。
1047 0
区块链数据探索:Bitcoin公链数据ETL
|
区块链
Hyperledger Fabric 2.x 动态更新智能合约
在上一篇文章中分享了智能合约的安装与使用,如果业务有变更代码需要修改怎么办呢?本文分享如何对已安装的合约进行版本更新。
251 0
Hyperledger Fabric 2.x 动态更新智能合约
|
Java 区块链 开发工具
Hyperledger Fabric 2.x 自定义智能合约
本文分享如何使用 Java 语言开发智能合约,以及合约的安装与使用。
683 0
Hyperledger Fabric 2.x 自定义智能合约
|
区块链 开发工具 数据安全/隐私保护