市值: $2.827T -4.84%
體積(24小時): $188.512B 68.83%
恐懼與貪婪指數:

38 - 害怕

  • 市值: $2.827T -4.84%
  • 體積(24小時): $188.512B 68.83%
  • 恐懼與貪婪指數:
  • 市值: $2.827T -4.84%
加密
主題
加密植物
資訊
加密術
影片
頂級加密植物

選擇語言

選擇語言

選擇貨幣

加密
主題
加密植物
資訊
加密術
影片

如何用 Solidity 編寫你的第一個智能合約? (分步教程)

Set up Node.js, Truffle, and Ganache; write an ERC-20 token using OpenZeppelin; compile, deploy locally, and test via Truffle console and JavaScript.

2026/01/17 00:00

設置開發環境

1. 安裝 Node.js 和 npm 以管理 Solidity 工具所需的依賴項。

2. 使用npm在全球範圍內安裝Truffle——一種廣泛採用的基於以太坊的智能合約開發框架。

3、安裝Ganache作為個人區塊鏈進行本地測試;它為私人賬戶提供預先充值的 ETH。

4. 使用truffle init配置一個新的 Truffle 項目以生成基本目錄,例如contracts/migrations/test/

5. 通過運行truffle 版本並確認與 Solidity 編譯器 v0.8.x 或更高版本的兼容性來驗證安裝完整性。

編寫基本的代幣合約

1. 在contracts/文件夾中創建一個名為MyToken.sol的新文件。

2.聲明Solidity版本編譯指示:編譯指示solidity ^0.8.20;以確保確定性的編譯行為。

3.導入OpenZeppelin的ERC-20實現: import '@openzeppelin/contracts/token/ERC-20/ERC-20.sol';

4. 定義合約繼承:合約MyToken為ERC20 { ... }並在構造函數中初始化名稱、符號和總供應量。

5. 使用 OpenZeppelin 的 AccessControl 庫中的onlyOwner修飾符添加僅限所有者的 mint 函數。

編譯和部署合約

1. 在migrations/2_deploy_contracts.js中編寫遷移腳本,實例化並部署100萬個代幣的MyToken

2.運行trufflecompile生成ABI和字節碼;確認沒有出現語法或版本不匹配錯誤。

3. 啟動 Ganache 並將其 RPC 服務器 URL(例如,http://127.0.0.1:7545)複製到開發網絡下的truffle-config.js中。

4. 執行truffle migrate --networkdevelopment部署合約並記錄交易哈希值和合約地址。

5. 通過檢查 Ganache 的事務日誌並驗證控制台輸出中出現的合約地址來確認部署成功。

通過 Truffle 控制台進行交互

1. 啟動連接到 Ganache 的 Truffle 控制台: truffle console --networkdevelopment

2. 獲取已部署的實例: let instance = wait MyToken.deployed();

3. 使用(await instance.totalSupply()).toString()查詢總供應量 — 期望輸出與初始薄荷值匹配。

4. 賬戶間轉賬: await instance.transfer('0xAb8483F64d9C6d1EcF9b849Ae677dC320f55a1B5', '1000')

5. 使用(await instance.balanceOf('0xAb8483F64d9C6d1EcF9b849Ae677dC320f55a1B5')).toString()驗證餘額更改。

使用 JavaScript 進行測試

1. 創建test/mytoken.js ,其中包含核心功能的 Mocha 風格測試用例。

2. 使用contract()定義測試上下文,並使用it()塊來斷言鑄造、傳輸和事件發射等行為。

3. 調用transfer 後,使用assert.equal(receipt.logs[0].event, 'Transfer')斷言正確的事件日誌。

4. 測試恢復條件:嘗試傳輸超過餘額的內容,並使用ExpectRevert實用程序驗證是否引發恢復

5. 使用truffle test運行測試,並確認所有斷言都通過,沒有超時或運行時異常。

常見問題解答

問:我可以在不使用 Truffle 的情況下部署 Solidity 合約嗎?答:是的。替代方案包括 Hardhat、Remix IDE 或使用編譯的字節碼和 ABI 直接調用 web3.js。

問:如果我忘記了接收 ETH 的函數中的payable關鍵字,會發生什麼情況?答:該函數將恢復任何嘗試發送 ETH 的交易,從而導致執行失敗和 Gas 消耗。

問:使用tx.origin進行訪問控制安全嗎?答:不行。 tx.origin可以通過網絡釣魚合約進行操縱,並且絕不能在權限檢查中替換msg.sender

問:如何在 Etherscan 上驗證我的合約源代碼?答:通過 Etherscan 的驗證表單提交準確的 Solidity 源代碼、編譯器版本、優化設置和構造函數參數。

免責聲明:info@kdj.com

所提供的資訊並非交易建議。 kDJ.com對任何基於本文提供的資訊進行的投資不承擔任何責任。加密貨幣波動性較大,建議您充分研究後謹慎投資!

如果您認為本網站使用的內容侵犯了您的版權,請立即聯絡我們(info@kdj.com),我們將及時刪除。

相關知識

如何使用LayerZero合約執行跨鏈消息?

如何使用LayerZero合約執行跨鏈消息?

2026-01-18 13:19:39

了解 LayerZero 架構1. LayerZero 作為一種輕量級、無需許可的互操作性協議運行,無需依賴可信中介或包裝資產即可實現區塊鏈之間的通信。 2. 它利用部署在每條鏈上的超輕節點(ULN)來驗證消息的完整性和一致性,而無需存儲完整的區塊鏈狀態。 3. 核心組件包括處理消息路由的 Endp...

如何實施EIP-712進行安全簽名驗證?

如何實施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?

如何使用 OpenZeppelin 合約構建安全的 dApp?

2026-01-18 11:19:49

了解 OpenZeppelin 合約基礎知識1. OpenZeppelin Contracts 是一個可重用、經過社區審核的智能合約組件庫,專為以太坊和 EVM 兼容的區塊鏈而構建。 2. 庫中的每個合約都遵循嚴格的安全實踐,包括遵守“檢查-效果-交互”模式以及廣泛使用訪問控制修飾符。 3. 該庫提...

如何使用LayerZero合約執行跨鏈消息?

如何使用LayerZero合約執行跨鏈消息?

2026-01-18 13:19:39

了解 LayerZero 架構1. LayerZero 作為一種輕量級、無需許可的互操作性協議運行,無需依賴可信中介或包裝資產即可實現區塊鏈之間的通信。 2. 它利用部署在每條鏈上的超輕節點(ULN)來驗證消息的完整性和一致性,而無需存儲完整的區塊鏈狀態。 3. 核心組件包括處理消息路由的 Endp...

如何實施EIP-712進行安全簽名驗證?

如何實施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?

如何使用 OpenZeppelin 合約構建安全的 dApp?

2026-01-18 11:19:49

了解 OpenZeppelin 合約基礎知識1. OpenZeppelin Contracts 是一個可重用、經過社區審核的智能合約組件庫,專為以太坊和 EVM 兼容的區塊鏈而構建。 2. 庫中的每個合約都遵循嚴格的安全實踐,包括遵守“檢查-效果-交互”模式以及廣泛使用訪問控制修飾符。 3. 該庫提...

看所有文章

User not found or password invalid

Your input is correct