首页 > 解决方案 > 为 Solana NFT 解析元数据和更新元数据的代码示例

问题描述

在 Solana 上,NFT 元数据存储在地址为共享合约 Token Metadata Program 拥有的账户中metaqbxxUerdq28cj1RbAWkYQm3ybzjb6a8bt518x1s

我需要一个清晰、简洁的代码示例来说明如何使用一些现有的库来获取特定 NFT 的元数据。让我们以这个 NFT 为例:一个 SolStone4itgFt6tSotypyVAaUkLJzpGQ5KXsJNhwpKBANMv49mf

到目前为止,我得到的最远的是复制 metaplex 库并使用这样的调用

 await getProgramAccounts(connection, METADATA_PROGRAM_ID, 'finalized');

但是,这将加载所有现有 NFT 的元数据。相反,我需要使用一些过滤器而不是'finalized'作为承诺参数。

metaplex 代码库中,我相信他们有一个按创建者地址过滤的示例。

filters: [
    {
        memcmp: {
            offset:
            1 + // key
            32 + // update auth
            32 + // mint
            4 + // name string length
            MAX_NAME_LENGTH + // name
            4 + // uri string length
            MAX_URI_LENGTH + // uri
            4 + // symbol string length
            MAX_SYMBOL_LENGTH + // symbol
            2 + // seller fee basis points
            1 + // whether or not there is a creators vec
            4 + // creators vec length
            i * MAX_CREATOR_LEN,
            bytes: whitelistedCreators[j].info.address,
        }
    }
]

所以理论上我应该能够更新这个过滤器来代替 NFT 自己的地址过滤,但我不知道如何在这里得到正确的位偏移以使过滤器准确。

在我能够读取 nft 元数据之后,接下来我需要一个代码示例来更新元数据。特别是 URI 字段。

标签: nftsolanatokenmetadataprogrammetaplex

解决方案


你几乎就在那里!

该地址4itgFt6tSotypyVAaUkLJzpGQ5KXsJNhwpKBANMv49mf实际上是一个代币铸币厂,如在资源管理器上所见:https ://explorer.solana.com/address/4itgFt6tSotypyVAaUkLJzpGQ5KXsJNhwpKBANMv49mf

这意味着您将使用与您找到的示例非常相似的调用,但不是过滤whitelistedCreators数组,而是过滤薄荷的位置,即 byte 1 + 32,假设我们可以信任代码中的注释. 这给出了一个函数调用:

getProgramAccounts(connection, METADATA_PROGRAM_ID, {
  filters: [
    {
      memcmp: {
        offset:
          1 + // key
          32 // update auth
        bytes: mintAddress.toBytes(),
      },
    },
  ],
})

要更新元数据,您可能需要使用该UpdateMetadata指令。看起来 Metaplex JS 库有一个实用功能可以做到这一点:https ://github.com/metaplex-foundation/metaplex/blob/9d5a5c6d668cd9c597cff8c63dfba00dee2f72f0/js/packages/common/src/actions/metadata.ts#L481


推荐阅读