写点什么

如何使用 NFTScan NFT API 在 Mint Blockchain 上开发 Web3 产品和协议

作者:NFT Research
  • 2024-05-24
    中国台湾
  • 本文字数:5206 字

    阅读完需:约 17 分钟

如何使用 NFTScan NFT API 在 Mint Blockchain 上开发 Web3 产品和协议

Mint Blockchain 是一个基于 OP Stack 构建的 L2 区块链,聚焦在 NFT 领域的创新型 L2 网络,致力于促进 NFT 资产协议标准的创新和现实商业场景中 NFT 资产的大规模采用。Mint Blockchain 的底层账本安全是完全基于以太坊网络安全共识构建的。同时作为 L2 网络,是一个完全兼容 EVM 的公共区块链网络,以太坊生态的开发者可以无缝将项目扩展到 Mint Blockchain 网络上来,为以太坊生态提供了有效的可扩展性。


根据 NFTScan 数据显示,截至 5 月 23 日,Mint Blockchain 上已累计发行 NFT 资产 387,477 枚,NFT Contract 37 个,产生交互记录 388,471 条,有过交互的钱包地址 381,141 个,总交易额 0.22 ETH。


Mint NFTScan:https://mint.nftscan.com/



创建 NFTScan 开发者账号在开始使用 NFTScan API 之前,首先需要访问开发者网站并创建一个账户。前往 NFTScan 官方网站点击 NFTScan API “Sign Up”按钮进行注册。https://developer.nftscan.com/user/signup


登录后在 Dashboard(面板)上找到自己独有的 API KAY,将其复制。访问 API 文档,将自己的 API KEY 输进 API 文档的相应位置。根据文档的指引,就可以开始使用 API 服务了。在 API 文档中,开发者可以找到多种可供选择的接口模式,根据需求来选择最合适的接口。


在 Dashboard 中,开发人员还可以查看自己 API 使用情况的统计数据,帮助记录历史使用数据。不仅如此,NFTScan 还为每位注册开发者提供 1M CU 的 API 调用服务,用于请求所有的 NFT API 接口,并且 CU 永不过期,用完为止!


查看 Mint NFT API 文档

在成功注册开发者账号获取 API Key 后,需要查看 NFTScan API 文档。API 文档包含了所有可以使用的 API 端点和参数,以及如何构建请求和处理响应的详细信息。请认真阅读 API 文档,并确保理解如何使用 API 来获取您需要的数据。NFTScan API 服务致力于帮助开发者改善获取 NFT 数据分析体验。


NFTScan 目前拥有全网最大最全的 NFT Collection 库,已支持 Ethereum、Solana、BNBChain、Bitcoin、Mint Blockchain 等在内 25 条区块链的 NFT 全量数据,所涵盖的 NFT 数据全、种类丰富,提供一整套的接口来获得 ERC721 和 ERC1155 资产以及交易、项目、市场统计等信息,现在支持 60 多个针对 EVM 兼容链的公共接口,以及针对 Solana、Aptos、Bitcoin、TON 的一批相同模型的接口,很大程度上满足了开发者索引多种类型的 NFT 数据的需求。


Mint NFT API 模型


主要包括了以下三个模型接口,包括里面一些 API 核心的字段的整体介绍和说明,方便开发者知道怎么去获取数据利用这些信息服务于自己正在构建的 Dapp 服务。


Assets API:"Assets"是 NFT 中最关键的数据字段,用于唯一标识和描述数字资产。开发者可以通过提取 Mint Blockchain 上 NFT 的"Assets"数据来获取全面的了解,并构建相关应用。"Assets"对象提供了数字资产的唯一标识以及其整个生命周期的数据,为开发者理解和应用 NFT 提供了基础。

Transactions API:交易模型代表了区块链上一个 NFT 资产的全量交易数据,为开发者提供 NFT 的完整生命周期交易信息。包括 NFT 的铸造、转移、销售、和其他交易活动,为开发者提供了深入了解 NFT 资产在 Mint 生态系统中的流动和演变过程的机会。NFTScan 不断地汇总来自各个区块链网络的 NFT 交易市场和相关交易合约信息,目前 NFTScan 已收录用于追踪和了解 NFT 市场的动态,同时也有助于开发者构建基于 NFT 的应用程序和工具。

Collections API:NFTScan 获取与 NFT Collections 相关的描述、社交媒体及其他基本信息等链下数据。NFTScan 通过各个区块链网络中最主流的 NFT 市场提供的 API 获取这些信息。此外当前地板价信息是基于 NFT 市场的订单信息的集中式数据,也是通过 API 可获取的。


1/ Retrieve Assets 系列


  • Get NFTs by account(通过钱包地址检索 NFT)

  • Get all NFTs by account(检索钱包地址的所有 NFT,并根据合约地址对 NFT 进行分组,如果账户地址拥有的 NFT 总数超过 2000 个,则返回的 NFT 将限制在 2000 个以下。在这种情况下,开发者和用户可以通过分页查询请求按账户获取该账户地址拥有的所有 NFT)

  • Get minted NFTs by account(检索该钱包地址的 Mint 的 NFT)

  • Get NFTs by contract(通过合约地址检索 NFT,并按 token_id 升序排序)

  • Get single NFT(检索单个 NFT)

  • Get multiple NFTs(同时检索多个合约地址的 NFT)

  • Search NFTs(该接口通过在请求正文中应用搜索筛选器来返回 NFT 资产列表。资产按 nftscan_id 升序排序)

  • Get NFTs by attributes(该接口返回一组属于具有属性的 NFT 合约地址的 NFT,NFT 按 token_id 升序排序)

  • Get all multi-chain NFTs by account(该接口返回账户地址拥有的所有多链 NFT,NFT 根据合约地址进行分组)


这里我们通过 Get NFTs by contract 接口为“/v2/assets/{contract_address}”来检索一个合约地址下 NFT 的详情信息,路径参数包括 contract_address 作为选择,这里我们查询的是合约地址 0x776fcec07e65dc03e35a9585f9194b8a9082cddb,名称为 GreenID 的详细数据。


点击 Try it,数据返回如下,数据响应结果显示该 NFT Collection 所有 item 的基础数据及元数据信息,这里我们选择的 GreenID,可以看到当前项目下一共 374248 个 Items,返回数据按照 token_id 进行排序,例如 id 为 1 的 item:


1)单个 item 基础数据:0x776fcec07e65dc03e35a9585f9194b8a9082cddb 及名称 GreenID,这里查询的 NFT Token id 为 1,在项目中的占比为 1,协议标准为 erc721,铸造时的钱包地址/持有者钱包地址,被铸造时的时间戳/Mint 的哈希地址/Token URI 的地址。latest_trade_price(上次成交价)/latest_trade_symbol(上次成交价的货币),latest_trade_timestamp(上次成交时间戳)等数据。

2)元数据:从该项目的元数据可以看出 Metadata 数据托管在 ipfs 上,token_uri:https://www.mintchain.io/api/tree/metadata/1,格式为 image/png,存储路径以及为对该图片的细节特征描述。

3)稀有度描述:得分及综合稀有度排名。


2/ Retrieve Transactions 系列


  • Get transactions by account(该接口返回钱包地址的 NFT 交易列表)

  • Get transactions by contract(该接口返回 NFT 合约地址的 NFT 交易列表)

  • Get transactions by NFT(该接口返回单个 NFT 的交易列表)

  • Search transactions(该接口返回在请求正文中应用搜索过滤器来返回 NFT 交易列表)

  • Get transactions by to address(该接口返回按交易参数过滤的 NFT 交易列表)

  • Get transactions by hash(该接口返回根据交易哈希列表查询到的交易记录)


这里我们通过 Get transactions by NFT “/v2/transactions/{contract_address}/{token_id}”这个接口,检索某 NFT 合约地址的下单个 NFT 交易记录,查询参数可选择交易的 NFT 事件类型(Mint/Transfer/Sale/Burn),使用 ';' 分隔多个事件。


同样这里我们检索 Mint Commemorative NFT tokenID 为 1 的 NFT 交易记录。按照 Mint/Transfer/Sale/Burn 选择所有事件类型,结果响应数据包含这个 NFT Item 下所有交易关键数据,如交易哈希值、From 和 To 地址、区块信息、消耗 Gas、交易时间戳等基础数据等 NFT 交易的特征信息。数据返回显示该 item 目前只有一条 Mint 相关交易记录。



3/ Retrieve Collections 系列


  • Get an NFT collection(根据 Collection 的合约地址查询详情,包括概览及按照描述对 Item 进行分类,持有者分布、平均价格、地板价等基本概括信息)

  • Search NFT collections(此接口通过在请求正文中应用搜索过滤器来返回 Collection 列表的信息,Collection 按部署块编号升序排序)

  • Get NFT collections by account(该接口返回具有给定账户地址的项目列表信息,Collection 按地板价从高到低排序)

  • Get NFT collections by ranking(该接口返回具有给定排序字段的项目列表信息,Collection 按给定的排序字段和给定的排序方向排序


这里我们通过接口 Get an NFT collection “/v2/collections/{contract_address}”检索地址为 0x776fcec07e65dc03e35a9585f9194b8a9082cddb 名称为 GreenID 的详情信息:



4/ Collection Statistics:Collection 统计分析系列


  • Collection Statistics(该接口提供 NFT Collection 的分析统计概览数据)

  • Collection Trade Distribution(该接口主要提供项目交易分布)

  • Collection Trending Statistics(主要返回一个项目的 Trading 统计排序)

  • Collection Holding Amount Distribution(该接口可返回 NFT 项目持有量的分布信息)

  • Collection Holding Period Distribution(数据返回 NFT 项目持有期分布信息)

  • Collection Blue Chip Statistics(蓝筹项目统计概览数据)

  • Collection Blue Chip List(该项目涉及的蓝筹项目清单,可参考 NFTScan Blue Chip Collection)

  • Collection Top Holder(该 Collection 的顶级持有者分布)


这里我们通过接口 Collection Top Holder

“/v2/statistics/collection/holder/{contract_address}”主要返回一个 NFT Collection 下的持有量分布,可参考 NFTScan Holders:https://mint.nftscan.com/0x526d6479a3a63a92dc3f4280d36dba6fceea2f9f?module=Holders



5/ Account Statistics 系列


  • Account Overview Statistics(该接口返回账户地址的概览统计信息,参考 NFTScan Overview)

  • Account Holding Distribution(该接口返回账户地址的 NFT 持有分布统计信息,参考 NFTScan Portfolio)

  • Account Holding NFT Trending(该接口返回账户地址的 NFT 持有量(或数量)统计信息,参考 NFTScan Portfolio)


6/ Analytic Statistics 系列


该系列接口通常用于获取 NFTScan Mint Blockchain 上各与数据分析和统计有关的信息,如 Trade Ranking、Mint Amount 等等这类接口允许开发者或用户查询、分析、和检索与特定数据集或指标相关的统计数据。可以用于各种用途,包括市场分析、趋势追踪、投资决策、以及了解特定数据的性质。


7/ Refresh Metadata


  • Refresh NFT metadata

  • Refresh NFT metadata by contract

  • Submit spam contracts


Refresh Metadata 这类接口可以帮助开发者或用户提交后台刷新元数据任务,该任务审核后会刷新提交的指定 Item 或整个合约元数据,以及反馈垃圾诈骗合约地址。


8/ Other


  • Get latest block number(返回 NFTScan 已到达的最新块号)

  • Get the latest reorganization block numbers(返回最新的重组块号)

  • Get NFT amount by account(根据请求体中的搜索列表返回账户地址拥有的 ERC721 和 ERC1155 NFT 数量信息)

  • Get NFT owners by contract(返回 ERC721 NFT 合约地址的所有者列表,NFT 按 token_id 升序排序)

  • Get owners by an NFT(返回 ERC1155 NFT 的所有者列表, NFT 按 account_address 升序排序)


构建相关 NFT API 请求


构建 NFTScan 相关的 NFT 数据请求非常简单便捷。开发者只需要浏览 API 文档找到所需的接口,了解接口地址、请求方法、请求参数等信息。然后根据个人需求选择编程语言,比如 JavaScript、Python、Java 等,使用该语言的 HTTP 请求库发送构建好的请求到接口地址,编写代码时,开发者只需组织好接口参数,如合约地址、API Key 等,调用对应的 NFTScan 接口,就可以方便地获取到标准化的 JSON 格式数据。


这里我们使用接口 Get an NFT collection “/v2/collections/{contract_address}


” 对 Mint Blockchain 上的 GreenID 该项目的详情数据进行调取,地址为


0x776fcec07e65dc03e35a9585f9194b8a9082cddb,HTTP GET 请求访问 NFTScan 的 API 接口,使用 Python 的 requests 库,可以这样构建请求:



import requests
# Set API endpoint and contract addressapi_endpoint = "https://api.nftscan.com/v2/collections/"contract_address = "0xcfc4c2b14af5b1f8ed97e1717b009dca461d8461"
# Build the complete API request URLurl = api_endpoint + contract_address
# Send HTTP GET requestresponse = requests.get(url)
# Check if the request was successfulif response.status_code == 200: # If successful, parse the response data data = response.json() # Handle the response data, further processing or display can be done here print(data)else: # If the request failed, print the error message print("Request failed, status code:", response.status_code)
复制代码

代码解释:导入 requests 库:使用 import requests 导入所需的库。


定义函数 get_nft_collection_details:


contract_address:NFT 合约地址。


api_key:用于身份验证的 API Key。


构建 URL:将基础 URL 与 contract_address 进行拼接。


设置请求头:包括 Content-Type 和 x-api-key,后者用于身份验证。


发送请求:使用 requests.get 发送 GET 请求。


处理响应:


如果请求成功(状态码 200),返回 JSON 数据。


否则,返回错误信息。


此代码仅为示例,开发者需要参考实际应用进行构建,请确保将 your_api_key_here 替换为实际的 API Key。

用户头像

NFT Research

关注

还未添加个人签名 2022-06-30 加入

专注于 NFT 数据分析和调研

评论

发布
暂无评论
如何使用 NFTScan NFT API 在 Mint Blockchain 上开发 Web3 产品和协议_NFT_NFT Research_InfoQ写作社区