如何使用 NFTScan NFT API 在 Avalanche 網絡上开發 Web3 應用

2023-11-26 10:11:11

Avalanche 是一個高度可擴展網絡,支持每秒交易處理量(TPS)較高且交易手續費較低的定制應用程序專用區塊鏈,它的原生代幣是 AVAX。Avalanche 致力於在不影響速度或去中心化的前提下提升可擴展性。其核心平臺有三條區塊鏈:交易鏈(X 鏈)、合約鏈(C 鏈)及平臺鏈(P 鏈)。X 鏈用於創建和交易資產,C 鏈用於創建智能合約,P 鏈用於協調驗證者和子網。Avalanche-C 鏈是基於 Snowman 共識協議創建的合約鏈,支持智能合約,兼容 EVM,开發者可以方便快捷地在 C 鏈上部署智能合約和構建 DApp。 

就 NFTScan 數據來看,截至 11 月 24 日,Avalanche-C 網絡上已累計發行 NFT 資產 15,601,161 枚,NFT Collection 215,667 個,產生交易記錄 36,165,993 條,有過交互的錢包地址 2,321,649 個,總交易額 2,067,664.69 AVAX。

Avalanche-C NFTScan:

怎樣訪問 NFTScan NFT API

創建 NFTScan 开發者账號

在开始使用 NFTScan API 之前,首先需要訪問开發者網站並創建一個账戶。前往 NFTScan 官方網站點擊 NFTScan API “Sign Up”按鈕進行注冊。

登錄後在 Dashboard(面板)上找到自己獨有的 API KAY,將其復制。訪問 API 文檔,將自己的 API KEY 輸進 API 文檔的相應位置。根據文檔的指引,就可以开始使用 API 服務了。在 API 文檔中,开發者可以找到多種可供選擇的接口模式,根據需求來選擇最合適的接口。

在 Dashboard 中,开發人員還可以查看自己 API 使用情況的統計數據,幫助記錄歷史使用數據。不僅如此,NFTScan 還為每位注冊开發者提供 1M CU 的 API 調用服務,用於請求所有的 NFT API 接口,並且 CU 永不過期,用完為止!

查 Avalanche-C API 文檔

在成功注冊开發者账號獲取 API Key 後,需要查看 NFTScan API 文檔。API 文檔包含了所有可以使用的 API 端點和參數,以及如何構建請求和處理響應的詳細信息。請認真閱讀 API 文檔,並確保理解如何使用 API 來獲取您需要的數據。NFTScan API 服務致力於幫助开發者改善獲取 NFT 數據分析體驗。

NFTScan 目前擁有全網最大最全的 NFT Collection 庫,已支持 Ethereum、Solana、BNBChain、Bitcoin、TON、Polygon、zkSync、Aptos、Linea、Base、Avalanche、Arbitrum、Optimism、Scroll、Viction、Fantom、Moonbeam、PlatON、Cronos、Gnosis 20 條區塊鏈的 NFT 全量數據,所涵蓋的 NFT 數據全、種類豐富,提供一整套的接口來獲得 ERC721 和 ERC1155 資產以及交易、項目、市場統計等信息,現在支持 60 多個針對 EVM 兼容鏈的公共接口,以及針對 Solana、Aptos、Bitcoin、TON 的一批相同模型的接口,很大程度上滿足了开發者索引多種類型的 NFT 數據的需求。

Avalanche-C NFT API 模型

主要包括了以下三個模型接口,包括裏面一些 API 核心的字段的整體介紹和說明,方便开發者知道怎么去獲取數據利用這些信息服務於自己正在構建的 Dapp 服務。

Assets API:"Assets"是 NFT 中最關鍵的數據字段,用於唯一標識和描述數字資產。开發者可以通過提取 Avalanche-C 區塊鏈上 NFT 的"Assets"數據來獲取全面的了解,並構建相關應用。"Assets"對象提供了數字資產的唯一標識以及其整個生命周期的數據,為开發者理解和應用 NFT 提供了基礎。

Transactions API:交易模型代表了區塊鏈上一個 NFT 資產的全量交易數據,為开發者提供 NFT 的完整生命周期交易信息。包括 NFT 的 mint、轉移、銷售、和其他交易活動,為开發者提供了深入了解 NFT 資產在 Avalanche-C 生態系統中的流動和演變過程的機會。NFTScan 不斷地匯總來自各個區塊鏈網絡的 NFT 交易市場和相關交易合約信息,目前 NFTScan 已收錄用於追蹤和了解 NFT 市場的動態,同時也有助於开發者構建基於 NFT 的應用程序和工具。

Collections API:NFTScan 獲取與 NFT Collections 相關的描述、社交媒體及其他基本信息等都鏈下數據。NFTScan 通過各個區塊鏈網絡中最主流的 NFT 市場提供的 API 獲取這些信息。此外當前地板價信息是基於 NFT 市場的訂單信息的集中式數據,也是通過 API 可獲取的。

Avalanche-C 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 根據合約地址進行分組)

這裏我們通過一個錢包地址來檢索 NFT,使用接口 Get all NFTs by account:

/v2/account/own/all/{account_address},查詢參數包括協議標准:erc721/erc1155;排序字段:mint_time/own_time/last_trade_price(僅適用於 erc721)。我們這裏請求的是地址:

0xf2d850d518e4e165c17e6a9c7aa1ffdb00ca0244 Avalanche-C 鏈上所有的 erc721 協議的 NFT。

點擊 Try it 數據響應結果:該地址下一共持有 41 個 items,按 floor_price 降序排序,返回數據包括每個 NFT contract 地址以及 name,持有數量及該 contract 地址下 item 數量,地板價以及一些的基礎細節信息描述等等。

2/ Retrieve Transactions 系列

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

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

  • Get transactions by NFT(該接口返回單個 NFT 的 NFT 交易列表)

  • Search transactions(該接口返回在請求正文中應用搜索過濾器來返回 NFT 交易列表)

  • Get transactions by to address(該接口返回按交易參數過濾的 NFT 交易列表)

  • Get transactions by hash(該接口返回根據交易哈希列表查詢到的交易記錄)

這裏我們通過 Get transactions by contract 這個接口,檢索某個合約地址的交易記錄,查詢參數可選擇交易的 NFT 事件類型(Mint/Transfer/Sale/Burn),使用 ';' 分隔多個事件。這裏按照 Mint 的事件類型,輸入自己的 api-key 之後,結果響應數據包含這筆 NFT 交易的所有關鍵數據,如交易哈希值、區塊信息、From 和 To 地址、合約地址、交易時間戳等基礎數據外,還有 Token ID、交易金額等 NFT 交易的特徵信息。

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 NFT collections by account

“/v2/collections/own/{account_address}”檢索錢包地址依舊為 

0xf2d850d518e4e165c17e6a9c7aa1ffdb00ca0244 

協議標准為 erc721 的 NFT Collection 詳情信息,返回了 20 個 data:

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 Holding Period Distribution 

/v2/statistics/period/distribution/{contract_address}”主要返回一個 NFT Collection 的持有期分布信息,可參考 Avalanche-C 鏈上 NFTScan Holding Period Distribution:

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 Avalanche-C  網絡上各與數據分析和統計有關的信息,如 Trade Ranking、Mint Amount 等這類接口允許开發者或用戶查詢、分析、和檢索與特定數據集或指標相關的統計數據。可以用於各種用途,包括市場分析、趨勢追蹤、投資決策、以及了解特定數據的性質。

參考:

7/ Refresh Metadata

  • Refresh NFT metadata

  • Refresh NFT metadata by contract

Refresh Metadata 這類接口可以幫助开發者或用戶提交後臺刷新元數據任務,該任務審核後會刷新提交的指定 Item 或整個合約元數據。

8/ Other

  • Get latest block number(返回 NFTScan 已到達的最新塊號)

  • 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 獲取 NFT 數據,對开發者來說是極為輕松簡單的。整個過程只需要參考文檔,尋找所需接口的調用說明,包括請求地址、方法和必要參數。然後用任意一種熟悉的編程語言,如 JavaScript、Python 或者 Java,使用語言內置的請求庫,按文檔中接口說明構建請求,配置請求頭及參數信息。向定義的接口地址發送請求,即可獲得返回的 JSON 格式數據。开發者可以完全根據接口文檔來實施請求的構造,無需過多自己推導,整個調用流程極速,使用門檻很低。

例如,我們通過 Get transactions by contract 接口請求 

0x8927985b358692815e18f2138964679dca5d3b79 

該地址的交易記錄,使用接口:

“/v2/transactions/{contract_address}”,HTTP GET 請求訪問 NFTScan 的 API 端點,使用 Python 的 requests 庫,可以這樣構建請求:

總體而言,這段代碼發送了一個 HTTP GET 請求到指定的端點,可以作為一個基本框架,向 NFTScan 的 API 發送請求並獲取交易記錄數據,為進一步處理和分析數據提供了一個起點。

About NFTScan

NFTScan 成立於 2021 年初,總部位於香港,是全球領先的 NFT 數據基礎設施服務商,目前已支持 Bitcoin、Ethereum、BNBChain、Polygon、Solana、TON、Arbitrum、Optimism、zkSync、Aptos 等在內的 20 條主流區塊鏈網絡。NFTScan 團隊致力於為數以億計的 Web3 用戶提供簡潔高效的 NFT 檢索服務,為新一代金融科技公司提供安全穩定的多鏈 NFT 索引服務,用數據來推動 NFT 生態的繁榮發展!目前,NFTScan 在為包括 CMC、Binance NFT、Bybit、KuCoin、HashKey Group 、Mask Network、imToken、Enjin、Coin98 等在內的 5000+ 开發者提供多鏈 NFT 數據支持!

鄭重聲明:本文版權歸原作者所有,轉載文章僅為傳播信息之目的,不構成任何投資建議,如有侵權行為,請第一時間聯絡我們修改或刪除,多謝。

推薦文章

btc日內再次下跌 短线應當如何處理?

盡管以太坊現貨ETF獲批是個好消息,但市場反應卻不如預期。在消息公布後,以太坊價格出現了小幅下跌,...

加密蓮
134 3個月前

7月23日、BTC(合約)ETH(合約)行情分析及操作策略

昨日收益還是不錯的,日內給出的現價空單分別止盈我們目標點位,恭喜跟上的朋友喫肉。時間一晃到月底了,...

倪老師
134 3個月前

幣圈院士:血與淚的教訓!交易者為何總是撞死在同一棵樹上?

幣圈院士談。交易市場中的幾種“死法” 在幣圈市場鱗次櫛比的海洋,風起雲湧,時常讓人感到驚手不及。在...

幣圈院士
139 3個月前

7月23:Mt. Gox 比特幣錢包在市場緊縮的情況下轉移了價值 28.2 億美元的 BTC

7月23:Mt. Gox 比特幣錢包在市場緊縮的情況下轉移了價值 28.2 億美元的 BTC一個引...

168超神
131 3個月前

悅盈:比特幣68000的空完美落地反彈繼續看跌 以太坊破前高看回撤

一個人的自律中,藏着無限的可能性,你自律的程度,決定着你人生的高度。 人生沒有近路可走,但你走的每...

我是周悅盈
111 3個月前

btc完美盈利 晚間波動較大注意

昨日btc空單完美給到,最大化走出一千七百點空間~ btc: 日內开盤下跌繼續測試66000一线,...

加密蓮
121 3個月前