-
bitcoin $87959.907984 USD
1.34% -
ethereum $2920.497338 USD
3.04% -
tether $0.999775 USD
0.00% -
xrp $2.237324 USD
8.12% -
bnb $860.243768 USD
0.90% -
solana $138.089498 USD
5.43% -
usd-coin $0.999807 USD
0.01% -
tron $0.272801 USD
-1.53% -
dogecoin $0.150904 USD
2.96% -
cardano $0.421635 USD
1.97% -
hyperliquid $32.152445 USD
2.23% -
bitcoin-cash $533.301069 USD
-1.94% -
chainlink $12.953417 USD
2.68% -
unus-sed-leo $9.535951 USD
0.73% -
zcash $521.483386 USD
-2.87%
如何從頭開始創建 NFT 合約(ERC-721)?
ERC-721 mandates unique token IDs, owner tracking, and Transfer events; optional metadata via tokenURI enables rich NFTs—implemented securely using OpenZeppelin contracts.
2026/01/22 03:40
了解 ERC-721 標準規範
1. ERC-721定義了每個合規合約必須實現的一組強制函數和事件,包括ownerOf 、 safeTransferFrom和approve 。
2. 該標準強制執行唯一的代幣標識符——每個 NFT 必須有一個獨特的 uint256 ID,在任何給定時間映射到恰好一個所有者。
3. 元數據支持是可選的,但被廣泛採用; tokenURI函數返回一個指向包含名稱、描述和圖像鏈接的 JSON 的 URI。
4. Transfer 事件必鬚髮出帶有 from、to 和 tokenId 參數的Transfer ,以確保錢包和瀏覽器兼容性。
5. 基本 ERC-721 不要求支持枚舉,但許多實現添加了TotalSupply和tokenByIndex來進行市場索引。
搭建開發環境
1. 安裝 Node.js 和 npm 來管理 Hardhat 或 Foundry 等依賴項,以進行本地編譯和測試。
2. 使用npm init -y初始化一個新項目,並通過npm install @openzeppelin/contracts安裝 OpenZeppelin Contracts。
3. 配置 Hardhat 配置文件以連接到 Sepolia 或本地 Anvil 網絡以進行部署模擬。
4. 在contracts目錄下創建一個名為MyNFT.sol的Solidity文件,並導入OpenZeppelin的ERC721和Ownable模塊。
5. 定義構造函數參數,例如名稱和符號,然後使用這些值調用父 ERC721 構造函數。
編寫核心合約邏輯
1. 添加_baseTokenURI狀態變量來存儲元數據的根路徑,僅由合約所有者更新。
2. 重寫tokenURI函數,將_baseTokenURI與 tokenId 字符串連接起來,確保 IPFS 或 HTTP 端點正確解析。
3. 實現一個mint函數,該函數使用_safeMint將新令牌專門分配給 msg.sender 並遞增內部計數器。
4. 在setBaseURI等敏感函數上引入onlyOwner修飾符,以防止未經授權的元數據操作。
5. 包含supportsInterface覆蓋,以針對0x80ac58cd (ERC-721) 和0x5b5e139f (ERC-721 元數據) 接口ID 返回true。
在測試網上編譯和部署
1.運行npx Hardhatcompile生成ABI和字節碼;驗證沒有出現語法或繼承錯誤。
2. 編寫一個部署腳本,以“CryptoPanda”和“CPANDA”作為參數調用合約構造函數。
3. 在為部署者地址提供資金後,使用npx hardhat run scripts/deploy.js --network sepolia廣播交易。
4. 使用編譯期間使用的相同編譯器版本和優化設置在 Etherscan Sepolia 上驗證合約。
5. 使用 Etherscan 的“Write as Proxy”或 MetaMask 連接的 dApp 接口與已部署的合約進行交互,以觸發鑄造和傳輸。
常見問題解答
問:鑄造後我可以更改 tokenURI 嗎?答:是的,如果您的合約允許通過僅限所有者的 setter 函數進行更改,但更改它會追溯影響所有之前鑄造的代幣,除非您存儲每個代幣的 URI。
問:如果兩個代幣共享相同的 ID 會發生什麼?答:由於 OpenZeppelin 的_owners映射驗證強制執行重複映射檢查,合約將在鑄造期間恢復。
問:ERC-721 的 Gas 成本是否比 ERC-20 更高?答:是的,ERC-721 操作需要對每個代幣 ID 進行單獨的存儲寫入,從而導致鑄造和傳輸的 Gas 消耗量顯著增加。
問:我需要在合同中落實特許權使用費嗎?答:否——特許權使用費不屬於 ERC-721 規範的一部分。如果通過 ERC-2981 實現,OpenSea 等平台會從RoyaltyInfo函數中讀取版稅信息。
免責聲明:info@kdj.com
所提供的資訊並非交易建議。 kDJ.com對任何基於本文提供的資訊進行的投資不承擔任何責任。加密貨幣波動性較大,建議您充分研究後謹慎投資!
如果您認為本網站使用的內容侵犯了您的版權,請立即聯絡我們(info@kdj.com),我們將及時刪除。
- 比特幣一月慘淡,連續四個月下跌
- 2026-01-31 01:15:01
- 未來就在眼前:解密加密貨幣交易、自動化機器人和實時交易的不斷發展的優勢
- 2026-01-31 01:15:01
- 皇家造幣廠硬幣稀有:“煎蛋錯誤”1英鎊硬幣裂開,價值驚人
- 2026-01-31 01:10:01
- 皇家造幣廠硬幣的“煎蛋錯誤”引發價值狂潮:稀有硬幣售價超過面值 100 倍
- 2026-01-31 01:10:01
- 斯塔默的中國之行:圍繞黎智英案的戰略舞蹈
- 2026-01-31 01:05:01
- 樂觀的回購策略:戰略轉變直面 OP 揮之不去的弱點
- 2026-01-31 01:05:01
相關知識
如何使用LayerZero合約執行跨鏈消息?
2026-01-18 13:19:39
了解 LayerZero 架構1. LayerZero 作為一種輕量級、無需許可的互操作性協議運行,無需依賴可信中介或包裝資產即可實現區塊鏈之間的通信。 2. 它利用部署在每條鏈上的超輕節點(ULN)來驗證消息的完整性和一致性,而無需存儲完整的區塊鏈狀態。 3. 核心組件包括處理消息路由的 Endp...
如何實施EIP-712進行安全簽名驗證?
2026-01-20 22:20:26
EIP-712 概述和核心目的1. EIP-712 定義了以太坊應用程序中類型化結構化數據哈希和簽名的標準。 2. 它使錢包能夠在簽名請求期間顯示人類可讀的域和消息字段,而不是原始的十六進製字符串。 3. 該規範通過域分隔符哈希引入域分離,防止跨不同 dApp 或鏈的簽名重放。 4. 每個簽名的有效...
如何通過新合約交互獲得空投資格?
2026-01-24 21:00:23
了解合約交互要求1. 大多數空投活動都要求與部署在受支持的區塊鏈(例如以太坊、Arbitrum 或 Base)上的智能合約進行直接交互。 2. 交互通常涉及使用連接到 dApp 接口的錢包執行諸如approve() 、 stake()或mint()之類的函數。 3. 某些協議需要多種交易類型,例如將...
如何監控智能合約的安全警報?
2026-01-21 07:59:57
鏈上監控工具1. Etherscan和Blockscout等區塊鏈瀏覽器允許實時檢查合約字節碼、交易日誌和內部調用。 2. 在信任任何鏈上數據之前必須確認合約驗證狀態——未經驗證的合約存在高風險。 3. 事件日誌解析可以檢測異常狀態變化,例如意外的代幣轉移或所有權修改。 4. 可以針對特定事件簽名設...
如何建立自動支付合同並為其提供資金?
2026-01-26 08:59:35
了解智能合約部署1. 開發者必鬚根據gas效率和安全性要求選擇兼容的區塊鏈平台,例如以太坊、Polygon或Arbitrum。 2. Solidity 仍然是編寫支付自動化邏輯的主要語言,特別是對於定期或有條件的轉賬。 3. 在主網部署之前,使用 Hardhat 或 Foundry 等本地開發環境來...
如何使用 OpenZeppelin 合約構建安全的 dApp?
2026-01-18 11:19:49
了解 OpenZeppelin 合約基礎知識1. OpenZeppelin Contracts 是一個可重用、經過社區審核的智能合約組件庫,專為以太坊和 EVM 兼容的區塊鏈而構建。 2. 庫中的每個合約都遵循嚴格的安全實踐,包括遵守“檢查-效果-交互”模式以及廣泛使用訪問控制修飾符。 3. 該庫提...
如何使用LayerZero合約執行跨鏈消息?
2026-01-18 13:19:39
了解 LayerZero 架構1. LayerZero 作為一種輕量級、無需許可的互操作性協議運行,無需依賴可信中介或包裝資產即可實現區塊鏈之間的通信。 2. 它利用部署在每條鏈上的超輕節點(ULN)來驗證消息的完整性和一致性,而無需存儲完整的區塊鏈狀態。 3. 核心組件包括處理消息路由的 Endp...
如何實施EIP-712進行安全簽名驗證?
2026-01-20 22:20:26
EIP-712 概述和核心目的1. EIP-712 定義了以太坊應用程序中類型化結構化數據哈希和簽名的標準。 2. 它使錢包能夠在簽名請求期間顯示人類可讀的域和消息字段,而不是原始的十六進製字符串。 3. 該規範通過域分隔符哈希引入域分離,防止跨不同 dApp 或鏈的簽名重放。 4. 每個簽名的有效...
如何通過新合約交互獲得空投資格?
2026-01-24 21:00:23
了解合約交互要求1. 大多數空投活動都要求與部署在受支持的區塊鏈(例如以太坊、Arbitrum 或 Base)上的智能合約進行直接交互。 2. 交互通常涉及使用連接到 dApp 接口的錢包執行諸如approve() 、 stake()或mint()之類的函數。 3. 某些協議需要多種交易類型,例如將...
如何監控智能合約的安全警報?
2026-01-21 07:59:57
鏈上監控工具1. Etherscan和Blockscout等區塊鏈瀏覽器允許實時檢查合約字節碼、交易日誌和內部調用。 2. 在信任任何鏈上數據之前必須確認合約驗證狀態——未經驗證的合約存在高風險。 3. 事件日誌解析可以檢測異常狀態變化,例如意外的代幣轉移或所有權修改。 4. 可以針對特定事件簽名設...
如何建立自動支付合同並為其提供資金?
2026-01-26 08:59:35
了解智能合約部署1. 開發者必鬚根據gas效率和安全性要求選擇兼容的區塊鏈平台,例如以太坊、Polygon或Arbitrum。 2. Solidity 仍然是編寫支付自動化邏輯的主要語言,特別是對於定期或有條件的轉賬。 3. 在主網部署之前,使用 Hardhat 或 Foundry 等本地開發環境來...
如何使用 OpenZeppelin 合約構建安全的 dApp?
2026-01-18 11:19:49
了解 OpenZeppelin 合約基礎知識1. OpenZeppelin Contracts 是一個可重用、經過社區審核的智能合約組件庫,專為以太坊和 EVM 兼容的區塊鏈而構建。 2. 庫中的每個合約都遵循嚴格的安全實踐,包括遵守“檢查-效果-交互”模式以及廣泛使用訪問控制修飾符。 3. 該庫提...
看所有文章














