上一篇文章我介紹了EOS環(huán)境搭建,在安裝好eos的環(huán)境后,接下來要進(jìn)入的環(huán)節(jié)也就是智能合約的編寫和調(diào)試了,學(xué)習(xí)任何一門語言都是從helloworld開始的,eos也不例外!
(如果想更全面了解EOS技術(shù),建議去看看PDJ孟巖等大佬關(guān)于區(qū)塊鏈EOS最新技術(shù)專家解讀與入門點(diǎn)撥實(shí)錄視頻,很有啟發(fā),需要的話也可加我扣扣(2082049536)索要)
EOS的樣例智能合約給我們提供了一個(gè)hello的職能合約寫法! 閱讀下面的內(nèi)容之前,要先確保nodeos已經(jīng)處于啟動(dòng)狀態(tài)!
智能合約部分知識(shí)介紹
在contracts下有大量的樣例合約,我們先挑一個(gè)最好欺負(fù)的合約開始,作為我們的入門!

上圖中,可以看到2個(gè)關(guān)鍵文件,cpp和abi,其他合約中還有hpp文件,其中熟悉c的朋友當(dāng)然知道cpp和hpp代表什么,分別代表了c的源碼和頭文件。
wast文件,默認(rèn)沒有,后面介紹如何生成
wast是eos智能合約運(yùn)行的代碼,可以將c++,c#,go等語言的代碼翻譯為wast,可以理解為一種類似匯編的低級(jí)別語言,更好的被執(zhí)行。
abi文件
如果做過eth智能合約編寫,對(duì)abi文件不會(huì)陌生,abi是我們調(diào)用智能合約的入口,里面定義了action,struct,以及table等關(guān)鍵內(nèi)容,上述三個(gè)可謂是abi文件的三要素!
智能合約操作
賬號(hào)和錢包操作
之所以先講賬號(hào)和錢包操作,是因?yàn)楹罄m(xù)要使用到錢包和賬號(hào)!
創(chuàng)建錢包
如果不指定錢包名,直接創(chuàng)建默認(rèn)錢包,也就是default
cleos wallet create [-n walletname]
192:~ yk$ cleos wallet create
Creating wallet: defaultSave
password to use in the future to unlock this wallet.
Without password imported keys will not be retrievable.
"PW5JvcRVNkDSH1AV2MDdx6o2YyKXX7QGWhTKKQvrLZffPbvyqUxfY"
注意這個(gè)創(chuàng)建后的錢包密碼一定要備份起來
創(chuàng)建賬號(hào)
先創(chuàng)建key
192:~ yk$ cleos create key
Private key: 5JLFiS18r3HtB1tVgrx9EYBSxKEBdtUos1yca5D5bq9hwEoCKoT
Public key: EOS87h471dTjN9QU5G1VcBYuoZrxvKxdFu2bYNr1NPYp32EzoyKdE
創(chuàng)建賬號(hào)語法
cleos create account [OPTIONS] creator name OwnerKey ActiveKey
這時(shí)候之前的create key的結(jié)果就可以使用了,Ownerkey和activekey代表了兩個(gè)權(quán)限,eos賬戶管理的設(shè)計(jì)比較有趣,owner的權(quán)限夠大,active的權(quán)限小一些,先不管它,都統(tǒng)一用之前的公鑰就省事了。
192:~ yk$ cleos create account eosio yekai EOS87h471dTjN9QU5G1VcBYuoZrxvKxdFu2bYNr1NPYp32EzoyKdE EOS87h471dTjN9QU5G1VcBYuoZrxvKxdFu2bYNr1NPYp32EzoyKdEexecuted transaction: 73e932daea695369c146c2bc62e3e751c47be62b12cfdae48e735086f5461f2a 352 bytes 102400 cycles# eosio <= eosio::newaccount {"creator":"eosio","name":"yekai","owner":{"threshold":1,"keys":[{"key":"EOS87h471dTjN9QU5G1VcBYuoZr...
這里的yekai就是我要建立的賬戶名,eosio是創(chuàng)建者,超級(jí)用戶,以后也是付費(fèi)用戶才能創(chuàng)建賬號(hào)。?
接下來將賬號(hào)導(dǎo)入錢包
這里的yekai就是我要建立的賬戶名,eosio是創(chuàng)建者,超級(jí)用戶,以后也是付費(fèi)用戶才能創(chuàng)建賬號(hào)。 接下來將賬號(hào)導(dǎo)入錢包
cleos wallet import [OPTIONS] key
這個(gè)key我們使用之前create key得到的私鑰
192:~ yk$ cleos wallet import 5JLFiS18r3HtB1tVgrx9EYBSxKEBdtUos1yca5D5bq9hwEoCKoTimported private key for: EOS87h471dTjN9QU5G1VcBYuoZrxvKxdFu2bYNr1NPYp32EzoyKdE
部署合約
接下來應(yīng)該可以部署合約了,來到hello所在目錄
192:hello yk$ ls hello.*hello.abi hello.cpp hello.hi_rc.md當(dāng)前有hello.abi以及hello.cpp源碼文件,還缺少hello.wast文件,可以通過eosiocpp生成!
192:hello yk$ eosiocpp -o hello.wast hello.cpp
會(huì)看到很多輸出信息,沒有錯(cuò)誤就ok
192:hello yk$ ls hello.*hello.abi hello.cpp hello.hi_rc.md hello.wast
此時(shí)多了一個(gè)wast文件,來看看hello源碼文件
#includeusing namespace eosio;
class hello : public eosio::contract {
? public:
? ? ? using contract::contract;
? ? ? /// @abi action
? ? ? void hi( account_name user ) {
? ? ? ? print( "Hello, ", name{user} );
? ? ? }
};
EOSIO_ABI( hello, (hi) )
這個(gè)hello代碼中提供了一個(gè) hi的action,action本次先篇先不展開,我們先能調(diào)用即可。
先將合約部署:
cleos set contract [OPTIONS] account contract-dir [wast-file] [abi-file]
通過yekai賬戶來設(shè)置合約
192:hello yk$ cleos set contract yekai ../hello/
Reading WAST/WASM from ../hello/hello.wast...
Assembling WASM...
Publishing contract...
executed transaction: c28017f62ae6c6dbbaafa563ea8ded881ee6b79d5be5aa7f1965d1709d51ea4e? 4008 bytes? 2200576 cycles
#? ? ? ? eosio <= eosio::setcode? ? ? ? ? ? ? {"account":"yekai","vmtype":0,"vmversion":0,"code":"0061736d0100000001370b60027f7e0060027e7e0060017f...
#? ? ? ? eosio <= eosio::setabi? ? ? ? ? ? ? ? {"account":"yekai","abi":{"types":[],"structs":[{"name":"hi","base":"","fields":[{"name":"user","typ...
調(diào)用合約
接下來演示一下如何調(diào)用合約
cleos push action [OPTIONS] contract action data
這里的contract與賬戶是一對(duì)一的,所以你可以理解為就是賬戶yekai,后面的action data是要傳遞的數(shù)據(jù)。hi需要傳遞一個(gè)賬戶名字給他
192:hello yk$ cleos push action? yekai hi '{"user":"dinglinlin"}'
Error 3030033: transaction should have at least one required authority
Error Details:
transaction must have at least one authorization
192:hello yk$ cleos push action? yekai hi '{"user":"dinglinlin"}' -pyekai
executed transaction: 247f64fb75df825c44e94a08d6a051f0a3d4273e37c75727196a6e78a9a75796? 232 bytes? 102400 cycles
#? ? ? ? yekai <= yekai::hi? ? ? ? ? ? ? ? ? ? {"user":"dinglinlin"}
>> Hello, dinglinlin
可見調(diào)用時(shí)需要給定一個(gè)賬戶認(rèn)證的,也就是-p選項(xiàng)
思考如何擴(kuò)展?
hello合約展示完了,怎么樣證明理解了hello合約呢?能否對(duì)hello進(jìn)行改造,比如再增加一個(gè)bye的action,接口傳遞user和想說的話。
void void hi( account_name user ,string memo )
來嘗試一下吧,如果有比理解的可以關(guān)注我們,尋求答案!