?文章來(lái)源地址http://www.zghlxwxcb.cn/news/detail-633888.html
安裝 Truffle
構(gòu)建一個(gè)Truffle項(xiàng)目
瀏覽一下這個(gè)項(xiàng)目
測(cè)試項(xiàng)目
編譯智能合約
使用 Ganache 部署項(xiàng)目
與智能合約交互
搭建自連網(wǎng)絡(luò)
truflle初始化項(xiàng)目
Stairs upon the temple I climb and I crawl?
Wonder how much further I'll go
Feet that fall apart till I walk on my ankles
Can I finish
I just don't know
?
?簡(jiǎn)介:?truffle是以太坊(ethereum)開(kāi)發(fā)智能合約(smart contract)智能框架,本教程來(lái)安裝構(gòu)建一個(gè)基本的Truffle項(xiàng)目并部署一個(gè)智能合約到區(qū)塊鏈。
?truffle是以太坊(ethereum)開(kāi)發(fā)智能合約(smart contract)智能框架,本教程來(lái)安裝構(gòu)建一個(gè)基本的Truffle項(xiàng)目并部署一個(gè)智能合約到區(qū)塊鏈。
開(kāi)始本文之前希望你已經(jīng)了解區(qū)塊鏈、以太坊、智能合約等基本概念。
安裝 Truffle
安裝 Truffle 框架非常的簡(jiǎn)單,只需要一行命令:
npm install -g truffle
當(dāng)然前提是你已經(jīng)安裝好了NodeJS并且版本要在5.0以上。
Tunffle還要求一個(gè)運(yùn)行的以太坊客戶(hù)端,以便支持標(biāo)準(zhǔn)的JSON RPC API,有很多的選擇比如Ganache、geth。
構(gòu)建一個(gè)Truffle項(xiàng)目
要使用大量的Tunffle命令,我們通過(guò)使用一個(gè)現(xiàn)成的Tunffle項(xiàng)目來(lái)學(xué)習(xí)。第一步是創(chuàng)建一個(gè)Truffle項(xiàng)目。
我們可以創(chuàng)建一個(gè)空的項(xiàng)目模板,不過(guò)剛開(kāi)始構(gòu)建項(xiàng)目,我們可以使用Tunffle Boxs,里面有很多的示例應(yīng)用程序和項(xiàng)目模板。本文使用MetaCoin box,它創(chuàng)建一個(gè)可以在帳戶(hù)之間傳輸代幣的應(yīng)用程序示例。
1.為構(gòu)建Truffle項(xiàng)目創(chuàng)建新目錄:
mkdir MetaCoin
cd MetaCoin
2.下載 MetaCoin box,使用truffle unbox <box-name>
來(lái)下載各種示例,如果要建一個(gè)空的不包括智能合約的項(xiàng)目可以使用truffle init
。
truffle unbox metacoin
上述命令完成后,我們獲得一個(gè)有以下目錄結(jié)構(gòu)的項(xiàng)目:
- contracts/: Solidity編寫(xiě)的智能合約目錄。
- migrations/:腳本部署目錄。
- test/:用來(lái)測(cè)試應(yīng)用程序和智能合約的測(cè)試目錄。
- truffle.js/:Truffle 配置文件。
瀏覽一下這個(gè)項(xiàng)目
-
打開(kāi)
contracts/MetaCoin.sol
,這是一個(gè)用Solidity編寫(xiě)的智能合約文件,這個(gè)智能合約建了Metacoin代幣,我們可以注意到它引用了同目錄下的另外一個(gè)solidity編寫(xiě)的文件contracts/ConvertLib.sol
。 -
打開(kāi)
contracts/Migrations.sol
,這是一個(gè)單獨(dú)的Solidity文件,用來(lái)管理和更新部署的智能合同的狀態(tài)。這個(gè)文件每個(gè)Tunffle項(xiàng)目都有,通常不用管。 -
打開(kāi)
migrations/1_initial_deployment.js
文件,這個(gè)腳本是為了部署Migrations.sol
文件中的Migrations
合約。 -
打開(kāi)
migrations/2_deploy_contracts.js
文件,這個(gè)腳本是為了部署MetaCoin
合約,會(huì)按順序執(zhí)行完上一步的腳本后執(zhí)行。 -
打開(kāi)
test/TestMetacoin.sol
文件,這是一個(gè)Solidity編寫(xiě)的測(cè)試文件,確保你的合約正常工作。 -
打開(kāi)
test/metacoin.js
文件,這個(gè)腳本與上面的測(cè)試文件類(lèi)似。 -
打開(kāi)
truffle.js
文件,用于設(shè)置網(wǎng)絡(luò)信息和其他與項(xiàng)目相關(guān)的內(nèi)容。文件是空白的,沒(méi)關(guān)系,因?yàn)槲覀儗⑹褂靡粋€(gè)內(nèi)置有默認(rèn)值的Truffle命令。
測(cè)試項(xiàng)目
1.打開(kāi)終端,執(zhí)行命令:
truffle test ./test/TestMetacoin.sol
輸出結(jié)果是這樣的:
TestMetacoin
√ testInitialBalanceUsingDeployedContract (71ms)
√ testInitialBalanceWithNewMetaCoin (59ms)
2 passing (794ms)
2.運(yùn)行JavaScript測(cè)試:
truffle test ./test/metacoin.js
輸出結(jié)果是這樣的:
Contract: MetaCoin
√ should put 10000 MetaCoin in the first account
√ should call a function that depends on a linked library (40ms)
√ should send coin correctly (129ms)
3 passing (255ms)
編譯智能合約
truffle compile
輸出結(jié)果是這樣的:
Compiling .\contracts\ConvertLib.sol...
Compiling .\contracts\MetaCoin.sol...
Compiling .\contracts\Migrations.sol...
Writing artifacts to .\build\contracts
使用 Ganache 部署項(xiàng)目
當(dāng)使用Tuffle開(kāi)發(fā)一個(gè)多功能的私有鏈和控制臺(tái)時(shí)也可以使用ganache,它作為一個(gè)桌面應(yīng)用程序來(lái)啟動(dòng)私有鏈。對(duì)于以太坊和區(qū)塊鏈新手來(lái)說(shuō)ganache是一個(gè)更容易理解的工具,因?yàn)樗鼤?huì)顯示更多的信息給我們。
除了運(yùn)行Ganache之外,需要額外編輯一下Tunffle配置文件,以指向ganache實(shí)例。
1.下載和安裝?Ganache
2.打開(kāi)?truffle.js
?,用下面的內(nèi)容替換:
module.exports = {
networks: {
development: {
host: "127.0.0.1",
port: 7545,
network_id: "*"
}
}
};
這樣就可以使用Ganache的默認(rèn)參數(shù)進(jìn)行連接了。
3.保存一下這個(gè)文件。
4.啟動(dòng) Ganache
?文章來(lái)源:http://www.zghlxwxcb.cn/news/detail-633888.html
5.打開(kāi)終端,用Ganache部署智能合約到區(qū)塊鏈
truffle migrate
輸出結(jié)果是這樣的:
Using network 'development'.
Running migration: 1_initial_migration.js
Replacing Migrations...
... 0x63b393bd50251ec5aa3e159070609ee7c61da55531ff5dea5b869e762263cb90
Migrations: 0xd6d1ea53b3a7dae2424a0525d6b1754045a0df9f
Saving successful migration to network...
... 0xe463b4cb6a3bbba06ab36ac4d7ce04e2a220abd186c8d2bde092c3d5b2217ed6
Saving artifacts...
Running migration: 2_deploy_contracts.js
Replacing ConvertLib...
... 0xa59221bc26a24f1a2ee7838c36abdf3231a2954b96d28dd7def7b98bbb8a7f35
ConvertLib: 0x33b217190208f7b8d2b14d7a30ec3de7bd722ac6
Replacing MetaCoin...
... 0x5d51f5dc05e5d926323d580559354ad39035f16db268b91b6db5c7baddef5de5
MetaCoin: 0xcd2c65cc0b498cb7a3835cfb1e283ccd25862086
Saving successful migration to network...
... 0xeca6515f3fb47a477df99c3389d3452a48dfe507980bfd29a3c57837d6ef55c5
Saving artifacts...
內(nèi)容顯示的是交易id和你所部署的智能合約地址。
6.在Ganache中,點(diǎn)擊Transactions
?按鈕可以看到被處理的交易。
7.要與合約進(jìn)行交互,可以使用Truffle控制臺(tái)。類(lèi)似于Truffle Develop,唯一不同的是它連接到現(xiàn)有區(qū)塊鏈(在這種情況下,由Ganache生成的)
truffle console
你會(huì)看到下面的提示:
truffle(development)>
與智能合約交互
使用控制臺(tái)通過(guò)下面的方式進(jìn)行交互:
- 查看賬戶(hù)余額
MetaCoin.deployed().then(function(instance){return instance.getBalance(web3.eth.accounts[0]);}).then(function(value){return value.toNumber()});
- 看看有多少以太合適(并注意合約定義1個(gè)metacoin價(jià)值2以太)
MetaCoin.deployed().then(function(instance){return instance.getBalanceInEth(web3.eth.accounts[0]);}).then(function(value){return value.toNumber()});
- 從一個(gè)賬號(hào)轉(zhuǎn)賬到另一個(gè)賬號(hào)
MetaCoin.deployed().then(function(instance){return instance.sendCoin(web3.eth.accounts[1], 500);});
- 檢查是否收到metacoin
MetaCoin.deployed().then(function(instance){return instance.getBalance(web3.eth.accounts[1]);}).then(function(value){return value.toNumber()});
- 檢查給別人轉(zhuǎn)賬的賬戶(hù)
MetaCoin.deployed().then(function(instance){return instance.getBalance(web3.eth.accounts[0]);}).t
-
啟動(dòng)一個(gè)連接到節(jié)點(diǎn)的交互控制臺(tái),您可以參考文檔開(kāi)啟geth交互控制臺(tái)來(lái)建立一個(gè)交互控制臺(tái)
-
在交互控制臺(tái)輸入以下指令,創(chuàng)建一個(gè)以太坊賬戶(hù)。如果您已經(jīng)在節(jié)點(diǎn)上創(chuàng)建了以太坊賬戶(hù),您也可以使用已有賬戶(hù)完成后續(xù)操作。
?
// create a account that use empty password
var account = personal.newAccount("");
// using an existing account in node
// var account = eth.accounts[0]
// unlock account for 300 seconds with empty password
personal.unlockAccount(account, "", 300);
// set it as default account
web3.eth.defaultAccount = account;
-
使用solc或truffle等第三方編譯工具,編譯智能合約,獲取智能合約的ABI和字節(jié)碼(bytecode)。您可以參考編譯智能合約編譯您的智能合約。
-
在交互控制臺(tái)輸入以下示例命令,在Quorum網(wǎng)絡(luò)中部署智能合約。在您需要部署自己的智能合約時(shí),您需要將
abi
和bytecode
替換為您智能合約的編譯結(jié)果。?
// abi for contract
var abi = [{"constant":true,"inputs":[],"name":"storedData","outputs":[{"name":"","type":"uint256"}],"payable":false,"type":"function"},{"constant":false,"inputs":[{"name":"x","type":"uint256"}],"name":"set","outputs":[],"payable":false,"type":"function"},{"constant":true,"inputs":[],"name":"get","outputs":[{"name":"retVal","type":"uint256"}],"payable":false,"type":"function"},{"inputs":[{"name":"initVal","type":"uint256"}],"payable":false,"type":"constructor"}];
// compiled solidity bytecode code using https://github.com/jpmorganchase/quorum-examples/blob/master/examples/7nodes/simplestorage.sol
var bytecode = "0x6060604052341561000f57600080fd5b604051602080610149833981016040528080519060200190919050505b806000819055505b505b610104806100456000396000f30060606040526000357c0100000000000000000000000000000000000000000000000000000000900463ffffffff1680632a1afcd914605157806360fe47b11460775780636d4ce63c146097575b600080fd5b3415605b57600080fd5b606160bd565b6040518082815260200191505060405180910390f35b3415608157600080fd5b6095600480803590602001909190505060c3565b005b341560a157600080fd5b60a760ce565b6040518082815260200191505060405180910390f35b60005481565b806000819055505b50565b6000805490505b905600a165627a7a72305820d5851baab720bba574474de3d09dbeaabc674a15f4dd93b974908476542c23f00029";
var address = ""
var simpleContract = web3.eth.contract(abi);
var simple = simpleContract.new(42, {
from: account,
data: bytecode,
gas: 0x47b760
}, function(e, contract) {
if (e) {
console.log("err creating contract", e);
} else {
if (!contract.address) {
console.log("Contract transaction send: TransactionHash: " + contract.transactionHash + " waiting to be mined...");
} else {
console.log("Contract mined! Address: " + contract.address);
address = contract.address
console.log(contract);
}
}
});
-
當(dāng)部署智能合約的交易被共識(shí)節(jié)點(diǎn)打包,您可以在交互控制臺(tái)看到您部署的合約地址,后續(xù)您可以向該地址發(fā)起交易,調(diào)用智能合約。
?
整個(gè)過(guò)程主要演示chrome擴(kuò)展 METAMASK, OpenZepplin庫(kù)和truffle框架的使用。
搭建自連網(wǎng)絡(luò)
主要參考之前的以太坊-私有鏈搭建初步實(shí)踐, 這里只用單節(jié)點(diǎn)的網(wǎng)絡(luò)。
還是先準(zhǔn)備賬戶(hù):
mkdir node0 # 會(huì)在node0/keystore目錄里生成一個(gè)keyfile json文件 geth --datadir node0 account new #利用puppeth生成genesis.json的過(guò)程不表,參考上邊的鏈接 geth --datadir node0 init genesis.json # 把剛才的賬號(hào)的密碼寫(xiě)入node0/password文件 # 啟動(dòng)私鏈,順便開(kāi)啟console echo node0 > node0/password geth --datadir node0 --port 30000 --nodiscover --unlock '0' --password ./node0/password --mine --rpc --rpccorsdomain "*" --rpcapi "eth,net,web3,admin,personal" console
我們把這個(gè)賬號(hào)的json文件導(dǎo)入到chorme插件metamask里,便于后面調(diào)試和演示
?
ubuntu系統(tǒng)上的chrome插件會(huì)有窗口消失的bug,在URL欄里打開(kāi)chrome-extension://nkbihfbeogaeaoehlefnkodbefgpgknn/popup.html
truflle初始化項(xiàng)目
需要下載truffle命令號(hào)
npm install -g truffle mkdir token && cd token # 利用trulle下載token代筆示例 truffle unbox tutorialtoken npm intall zeppelin-solidity
如上必要的依賴(lài)框架和庫(kù)已經(jīng)下載到了本地, 接下來(lái)就創(chuàng)建自己的代幣合約
在contract目錄創(chuàng)建TutorialToken.sol文件,內(nèi)容如下:
pragma solidity ^0.4.11; import 'zeppelin-solidity/contracts/token/StandardToken.sol'; /** * @title SimpleToken * @dev Very simple ERC20 Token example, where all tokens are pre-assigned to the creator. * Note they can later distribute these tokens as they wish using `transfer` and other * `StandardToken` functions. */ contract TutorialToken is StandardToken { string public name = "TutorialToken"; string public symbol = "SIM"; uint256 public decimals = 18; uint256 public INITIAL_SUPPLY = 10000; /** * @dev Contructor that gives msg.sender all of existing tokens. */ function TutorialToken() { totalSupply = INITIAL_SUPPLY; balances[msg.sender] = INITIAL_SUPPLY; } }
在以太坊里幾乎所有操作都是當(dāng)做交易來(lái)看的,部署合約就是一種交易,交易就要花錢(qián)(gas消耗),所以truffle做的是增量部署(少消耗gas),現(xiàn)在在migrations
目錄添加新的部署文件2_deploy_contracts.js
。
var TutorialToken = artifacts.require("./TutorialToken.sol"); module.exports = function(deployer) { deployer.deploy(TutorialToken); };
一切準(zhǔn)備就緒,編譯,部署開(kāi)始:
?
# 編譯 truffle compile Compiling ./contracts/Migrations.sol... Compiling ./contracts/TutorialToken.sol... Compiling zeppelin-solidity/contracts/math/SafeMath.sol... Compiling zeppelin-solidity/contracts/token/BasicToken.sol... Compiling zeppelin-solidity/contracts/token/ERC20.sol... Compiling zeppelin-solidity/contracts/token/ERC20Basic.sol... Compiling zeppelin-solidity/contracts/token/StandardToken.sol... Writing artifacts to ./build/contracts # 根據(jù)truffle.js的配置進(jìn)行部署 truffle migrate Using network 'development'. Running migration: 1_initial_migration.js Deploying Migrations... ... 0x65ccd2d6a4f4248466dd7887da7a2ac35d18c7ab0ec826cb25580bc785a2c3b8 Migrations: 0xc64569558f90302f4b3884929ac5540c645674dc Saving successful migration to network... ... 0xf9043ca886d352f05a05642047f63eed11d9b328fb815becc68baffc4d953d60 Saving artifacts... Running migration: 2_deploy_contracts.js Deploying TutorialToken... ... 0x19350625474c36316046b103e671eaad45834a60c17a5b9c64cf96316754560f TutorialToken: 0x7f469dc1ec17c3b7c52a3ad74611cb4b7e6807e1 Saving successful migration to network... ... 0xe57ba56dd5f1b18d410577def8bc7089f7de56e8d8718c3098430995d4b81353 Saving artifacts...
順便分享兩個(gè)教程給大家,可以看一眼:
一個(gè)適合區(qū)塊鏈新手的以太坊DApp開(kāi)發(fā):
http://xc.hubwiz.com/course/5a952991adb3847553d205d1
一個(gè)用區(qū)塊鏈、星際文件系統(tǒng)(IPFS)、Nodejs和MongoDB構(gòu)建電商平臺(tái):
http://xc.hubwiz.com/course/5abbb7acc02e6b6a59171dd6
?
?
?
?
?
?
到了這里,關(guān)于如何使用Truffle開(kāi)發(fā)太坊智能及其區(qū)塊鏈的文章就介紹完了。如果您還想了解更多內(nèi)容,請(qǐng)?jiān)谟疑辖撬阉鱐OY模板網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關(guān)文章,希望大家以后多多支持TOY模板網(wǎng)!