智能合约开发环境搭建及 Hello World 合约
智能合約開發環境搭建及 Hello World 合約
如果你對于以太坊智能合約開發還沒有概念(本文會假設你已經知道這些概念),建議先閱讀入門篇。
就先學習任何編程語言一樣,入門的第一個程序都是 Hello World。今天我們來一步一步從搭建以太坊智能合約開發環境開始,講解智能合約的 Hello World 如何編寫。
開發環境搭建
Solidity 安裝
強烈建議新手使用?Remix -Solidity IDE?來進行開發。
Remix 是一個基于瀏覽器的?Solidity,就可以不用安裝 Solidity,本文的 Hello World 教程也將基于 Remix Solidity IDE 來進行。
如果你想自己安裝請參考?Solidity 安裝指引。
更新,開發環境搭建還可以看另一篇文章:?搭建智能合約開發環境 Remix IDE 及使用。
geth 安裝
Mac 下安裝命令如下:其他平臺參考:geth 官方安裝指引
| 1 2 | brew tap ethereum/ethereum brew install ethereum |
?
brew 是 Mac 下的包管理工具,和 Ubuntu 里的 apt-get 類似
安裝完以后,就是把 geth 控制臺啟動。
啟動環境
在入門篇講過,geth 是一個以太坊客戶端,現在利用 geth啟動一個以太坊(開發者)網絡節點。
| 1 | geth --datadir testNet --dev console 2>> test.log |
執行命名后,會進入 geth 控制臺,這時光標停在一個向右的箭頭處,像這樣:
命令參數說明(更多命令詳解可閱讀?Geth 命令用法 - 參數詳解篇):
—dev?啟用開發者網絡(模式),開發者網絡會使用 POA 共識,默認預分配一個開發者賬戶并且會自動開啟挖礦。
—datadir?后面的參數是區塊數據及秘鑰存放目錄。
第一次輸入命令后,它會放在當前目錄下新建一個 testNet 目錄來存放數據。
console?進入控制臺
2>> test.log?表示把控制臺日志輸出到 test.log 文件
為了更好的理解,建議新開一個命令行終端,實時顯示日志:
| 1 | tail -f test.log |
?
準備賬戶
部署智能合約需要一個外部賬戶,我們先來看看分配的開發者賬戶,在控制臺使用以下命令查看賬戶:
| 1 | > eth.accounts |
?
回車后,返回一個賬戶數組,里面有一個默認賬戶,如:
也可以使用 personal.listAccounts 查看賬戶,
再來看一下賬戶里的余額,使用以下命令:
| 1 | > eth.getBalance(eth.accounts[0]) |
?
eth.accounts[0]?表示賬戶列表第一個賬戶
回車后,可以看到大量的余額,如:
1.15792089237316195423570985008687907853269… e+77
開發者賬戶因余額太多,如果用這個賬戶來部署合約時會無法看到余額變化,為了更好的體驗完整的過程,這里選擇創建一個新的賬戶。
創建賬戶
使用以下命令創建賬戶:
| 1 | > personal.newAccount("TinyXiong") |
?
TinyXiong 為新賬戶的密碼,回車后,返回一個新賬戶。
這時我們查看賬戶列表:
| 1 | > eth.accounts |
?
可以看到賬戶數組你包含兩個賬戶,新賬戶在第二個(索引為 1)位置。
現在看看賬戶的余額:
| 1 2 | > eth.getBalance(eth.accounts[1]) 0 |
?
回車后,返回的是 0,新賬戶是 0。結果如:
給新賬戶轉賬
我們知道沒有余額的賬戶是沒法部署合約的,那我們就從默認賬戶轉 1 以太幣給新賬戶,使用以下命令(請使用你自己 eth.accounts 對應輸出的賬戶):
| 1 | eth.sendTransaction({from: '0xb0ebe17ef0e96b5c525709c0a1ede347c66bd391', to: '0xf280facfd60d61f6fd3f88c9dee4fb90d0e11dfc', value: web3.toWei(1, "ether")}) |
?
在打開的?tail -f test.log?日志終端里,可以同時看到挖礦記錄
再次查看新賬戶余額,可以新賬戶有 1 個以太幣
解鎖賬戶
在部署合約前需要先解鎖賬戶(就像銀行轉賬要輸入密碼一樣),使用以下命令:
| 1 | personal.unlockAccount(eth.accounts[1],"TinyXiong"); |
?
“TinyXiong” 是之前創建賬戶時的密碼
解鎖成功后,賬戶就準備完畢啦,接下來就是編寫合約代碼。
編寫合約代碼
現在我們來開始編寫第一個智能合約代碼,solidity 代碼如下:
| 1 2 3 4 5 6 7 8 9 10 11 12 | pragma solidity ^0.4.18; contract hello {string greeting;function hello(string _greeting) public {greeting = _greeting;}function say() constant public returns (string) {return greeting;} } |
簡單解釋下,我們定義了一個名為 hello 的合約,在合約初始化時保存了一個字符串(我們會傳入 hello world),每次調用 say 返回字符串。
把這段代碼寫 (拷貝) 到?Browser-Solidity,如果沒有錯誤,點擊 Details 獲取部署代碼,如:
在彈出的對話框中找到 WEB3DEPLOY 部分,點拷貝,粘貼到編輯器后,修改初始化字符串為 hello world。
solidity 在博文寫作時(2017/11/24),版本為 0.4.18,solidity 發展非常快,solidity 版本之間有可能不能兼容,這是你可以在 Browser-Solidity 的 Settings 里選擇對應的編譯器版本。
Browser-Solidity 也不停的更新中,截圖可能和你看到的界面不一樣。
部署合約
Browser-Solidity 生成的代碼,拷貝到編輯器里修改后的代碼如下:
| 1 2 3 4 5 6 7 8 9 10 11 12 13 14 | var _greeting = "Hello World" ; var helloContract = web3.eth.contract([{"constant":true,"inputs":[],"name":"say","outputs":[{"name":"","type":"string"}],"payable":false,"stateMutability":"view","type":"function"},{"inputs":[{"name":"_greeting","type":"string"}],"payable":false,"stateMutability":"nonpayable","type":"constructor"}]); var hello = helloContract.new(_greeting,{from: web3.eth.accounts[1],data: '0x6060604052341561000f57600080fd5b6040516102b83803806102b8833981016040528080518201919050508060009080519060200190610041929190610048565b50506100ed565b828054600181600116156101000203166002900490600052602060002090601f016020900481019282601f1061008957805160ff19168380011785556100b7565b828001600101855582156100b7579182015b828111156100b657825182559160200191906001019061009b565b5b5090506100c491906100c8565b5090565b6100ea91905b808211156100e65760008160009055506001016100ce565b5090565b90565b6101bc806100fc6000396000f300606060405260043610610041576000357c0100000000000000000000000000000000000000000000000000000000900463ffffffff168063954ab4b214610046575b600080fd5b341561005157600080fd5b6100596100d4565b6040518080602001828103825283818151815260200191508051906020019080838360005b8381101561009957808201518184015260208101905061007e565b50505050905090810190601f1680156100c65780820380516001836020036101000a031916815260200191505b509250505060405180910390f35b6100dc61017c565b60008054600181600116156101000203166002900480601f0160208091040260200160405190810160405280929190818152602001828054600181600116156101000203166002900480156101725780601f1061014757610100808354040283529160200191610172565b820191906000526020600020905b81548152906001019060200180831161015557829003601f168201915b5050505050905090565b6020604051908101604052806000815250905600a165627a7a723058204a5577bb3ad30e02f7a3bdd90eedcc682700d67fc8ed6604d38bb739c0655df90029',gas: '4700000'}, function (e, contract){console.log(e, contract);if (typeof contract.address !== 'undefined') {console.log('Contract mined! address: ' + contract.address + ' transactionHash: ' + contract.transactionHash);}}); |
第 1 行:修改字符串為 Hello World
第 2 行:修改合約變量名
第 3 行:修改合約實例變量名,之后可以直接用實例調用函數。
第 6 行:修改部署賬戶為新賬戶索引,即使用新賬戶來部署合約。
第 8 行:準備付的 gas 費用,IDE 已經幫我們預估好了。
第 9 行:設置部署回調函數。
拷貝回 geth 控制臺里,回車后,看到輸出如:
| 1 | Contract mined! address: 0x79544078dcd9d560ec3f6eff0af42a9fc84c7d19 transactionHash: 0xe2caab22102e93434888a0b8013a7ae7e804b132e4a8bfd2318356f6cf0480b3 |
?
說明合約已經部署成功。
在打開的?tail -f test.log?日志終端里,可以同時看到挖礦記錄
現在我們查看下新賬戶的余額:
| 1 | > eth.getBalance(eth.accounts[1]) |
?
是不是比之前轉賬的余額少呀!
運行合約
| 1 2 | > hello.say() "Hello World" |
輸出 Hello World,我們第一個合約 Hello World,成功運行了。
運行截圖如下:
本文會隨 geth,solidity 語言版本升級保持更新,查看本文原始鏈接:https://learnblockchain.cn/2017/11/24/init-env/
總結
以上是生活随笔為你收集整理的智能合约开发环境搭建及 Hello World 合约的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 硬核! 逛了4年Github ,一口气把
- 下一篇: 开启 Truffle Ganache