如何使用 NFTScan NFT API 在 BNB Chain 網絡上开發 Web3 應用
BNB Chain 是一條以太坊虛擬機兼容的區塊鏈,是加密資產行業頂尖項目的測試和前沿探索。通過引入權益權威證明(PoSA)共識機制,BNB Chain 創建了驗證一個允許節點、代幣持有者、开發者和用戶都能夠從區塊鏈中獲益的生態系統,享受更高的性能和更充裕的創新空間,BNB Chain 仍然是一個社區驅動、开源且去中心化的生態系統。
NFTScan 數據顯示,截止 11 月 2 日,BNB Chain 鏈上一共累計發行 NFT 資產 195,093,986 枚,NFT Collection 608,766 個,產生交易記錄 435,980,676 條,有過交互的錢包地址 26,946,054 個,總交易額 1,412,382.57 BNB。
BNB NFScan:
NFTScan 提供的 API,开發者可以實現高效自動化地獲取和處理海量 NFT 數據,無需人工操作和復雜判斷,大大降低了开發成本。API 可以輕松實現高頻率監測,降低人力成本。此外,NFTScan API 返回規範化的數據格式,使得开發和優化監測工具變得更加簡單高效,自定義的參數設置也讓开發者可以靈活地定制屬於自己的解決方案。當前除了 15 條 EVM 兼容鏈,NFTScan 還支持了另外 4 條是非 EVM 區塊鏈:Bitcoin、Aptos、Solana、TON。
怎樣訪問 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 永不過期,用完為止!
查看 BNB 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、Fantom、Moonbeam、PlatON、Cronos、Gnosis 19 條區塊鏈的 NFT 全量數據,所涵蓋的 NFT 數據全、種類豐富,提供一整套的接口來獲得 ERC721 和 ERC1155 資產以及交易、項目、市場統計等信息,現在支持 60 多個針對 EVM 兼容鏈的公共接口,以及針對 Solana、Aptos、Bitcoin、TON 的一批相同模型的接口,很大程度上滿足了开發者索引多種類型的 NFT 數據的需求。
BNB Chain NFT API 模型
主要包括了以下三個模型接口,包括裏面一些 API 核心的字段的整體介紹和說明,方便开發者知道怎么去獲取數據利用這些信息服務於自己正在構建的 Dapp 服務。
Assets API:"Assets"是 NFT 中最關鍵的數據字段,用於唯一標識和描述數字資產。开發者可以通過提取 BNB Chain 區塊鏈上 NFT 的"Assets"數據來獲取全面的了解,並構建相關應用。"Assets"對象提供了數字資產的唯一標識以及其整個生命周期的數據,為开發者理解和應用 NFT 提供了基礎。
Transactions API:交易模型代表了區塊鏈上一個 NFT 資產的全量交易數據,為开發者提供 NFT 的完整生命周期交易信息。包括 NFT 的 mint、轉移、銷售、和其他交易活動,為开發者提供了深入了解 NFT 資產在 BNB 生態系統中的流動和演變過程的機會。NFTScan 不斷地匯總來自各個區塊鏈網絡的 NFT 交易市場和相關交易合約信息,目前 NFTScan 已收錄用於追蹤和了解 NFT 市場的動態,同時也有助於开發者構建基於 NFT 的應用程序和工具。
Collections API:NFTScan 獲取與 NFT Collections 相關的描述、社交媒體及其他基本信息等都鏈下數據。NFTScan 通過各個區塊鏈網絡中最主流的 NFT 市場提供的 API 獲取這些信息。此外當前地板價信息是基於 NFT 市場的訂單信息的集中式數據,也是通過 API 可獲取的。
BNB 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 升序排序。注意:僅使用 block_number 條件過濾數據時,block_number_start 和 block_number_end 之間的範圍不能超過 10000)
Get NFTs by attributes(該接口返回一組屬於具有屬性的 NFT 合約地址的 NFT,NFT 按 token_id 升序排序)
Get all multi-chain NFTs by account(該接口返回账戶地址擁有的所有多鏈 NFT,NFT 根據合約地址進行分組)
這裏我們通過 Get single NFT 接口為
“/v2/assets/{contract_address}/{token_id}”
來檢索一個合約地址下的某單個 NFT Item 的詳情信息,路徑參數包括 contract_address/token_id 作為選擇,這裏我們查詢的是 Pancake Squad 且 token id 為 1 的 NFT。
點擊 Try it,數據返回如下,主要包括 NFT 資產合約地址的基礎信息查詢,元數據信息及稀有度描述。
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 NFT
“/v2/transactions/{contract_address}/{token_id}”這個接口,檢索某單個 NFT Item 的交易記錄,查詢參數可選擇交易的 NFT 事件類型(Mint/Transfer/Sale/Burn),使用 ';' 分隔多個事件。
同樣這裏我們檢索 Pancake Squad 且 token id 為 1 的 NFT。按照 Mint 的事件類型,結果響應數據包含這筆 NFT 交易的所有關鍵數據,如交易哈希值、From 和 To 地址、區塊信息、消耗 Gas、交易時間戳等基礎數據等 NFT 交易的特徵信息。
3/ Retrieve Collections 系列
Get an NFT collection(根據 Collection 的合約地址查詢詳情,包括概覽及按照描述對 Item 進行分類,持有者分布、平均價格、地板價等基本概括信息)
Search NFT collections(此接口通過在請求正文中應用搜索過濾器來返回 Collection 列表的信息,Collection 按部署塊編號升序排序。注意:僅使用 block_number 條件篩選數據時,block_number_start 和 block_number_end 之間的範圍不能超過 10000)
Get NFT collections by account(該接口返回具有給定账戶地址的項目列表信息,Collection 按地板價從高到低排序)
Get NFT collections by ranking(該接口返回具有給定排序字段的項目列表信息,Collection 按給定的排序字段和給定的排序方向排序)
這裏我們通過接口 Get an NFT collection
“/v2/collections/{contract_address}”檢索地址為
0x0a8901b0e25deb55a87524f0cc164e9644020eba 名稱為 Pancake Squad 的詳情信息:
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 Amount Distribution
“/v2/statistics/amount/distribution/{contract_address}”主要返回一個 NFT Collection 下的持有量分布,可參考 NFTScan Amount 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 Ethererum 網絡上各與數據分析和統計有關的信息,如 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 的 API 文檔中找到所需的 BNB API 接口和參數後,可以使用選擇的編程語言(如 Python、Java、JavaScript 等)編寫 API 請求代碼。以下是一個簡單的示例,演示如何使用 Python 來進行 API 請求:
在上述示例中,我們構建了 API 接口和合約地址,然後使用 requests.get 方法發起 GET 請求以檢索 NFT 集合的詳細信息。如果請求成功,开發者可以從 API 響應的 JSON 數據中提取有關 NFT 集合的信息並進行處理。
請確保在 contract_address 中替換為實際的合約地址。此示例使用 Python 的 requests 庫來執行請求,如果使用其他編程語言,开發者需要相應地調整請求方法和庫。
鄭重聲明:本文版權歸原作者所有,轉載文章僅為傳播信息之目的,不構成任何投資建議,如有侵權行為,請第一時間聯絡我們修改或刪除,多謝。
7月23:Mt. Gox 比特幣錢包在市場緊縮的情況下轉移了價值 28.2 億美元的 BTC
7月23:Mt. Gox 比特幣錢包在市場緊縮的情況下轉移了價值 28.2 億美元的 BTC一個引...
悅盈:比特幣68000的空完美落地反彈繼續看跌 以太坊破前高看回撤
一個人的自律中,藏着無限的可能性,你自律的程度,決定着你人生的高度。 人生沒有近路可走,但你走的每...
NFT_Research
文章數量
117粉絲數
0