這篇文章主要講解了“EOS區(qū)塊鏈智能合約開發(fā)方法是什么”,文中的講解內(nèi)容簡(jiǎn)單清晰,易于學(xué)習(xí)與理解,下面請(qǐng)大家跟著小編的思路慢慢深入,一起來(lái)研究和學(xué)習(xí)“EOS區(qū)塊鏈智能合約開發(fā)方法是什么”吧!
霞浦網(wǎng)站建設(shè)公司創(chuàng)新互聯(lián)公司,霞浦網(wǎng)站設(shè)計(jì)制作,有大型網(wǎng)站制作公司豐富經(jīng)驗(yàn)。已為霞浦上千多家提供企業(yè)網(wǎng)站建設(shè)服務(wù)。企業(yè)網(wǎng)站搭建\外貿(mào)網(wǎng)站建設(shè)要多少錢,請(qǐng)找那個(gè)售后服務(wù)好的霞浦做網(wǎng)站的公司定做!
EOS智能合約開發(fā)需要使用llvm
和abigen
來(lái)生成abi
文件, 為此eos提供了一個(gè)名為eosiocpp
的工具。
首先,編寫一個(gè)ahello.cpp文件 - EOS的合約開發(fā)使用C++語(yǔ)言:
# mkdir /home/centos/sc/ahello # cd /home/centos/sc/ahello # vim ahello.cpp
將以下內(nèi)容插入到ahello.cpp文件中:
#include#include using namespace eosio; class hello : public eosio::contract { public: using contract::contract; /// @abi action void hi( account_name user ) { print( "Hello, World", name{user} ); } }; EOSIO_ABI( hello, (hi) )
接下來(lái),編譯并創(chuàng)建一個(gè)wast(web程序集)文件和一個(gè)abi文件。
# eosiocpp -o ahello.wast ahello.cpp # eosiocpp -g ahello.abi ahello.cpp
在部署合約之前,我們需要?jiǎng)?chuàng)建測(cè)試用的錢包、密鑰和帳戶。
首先,使用EOS客戶端cleos
創(chuàng)建一個(gè)名為scuser
錢包,EOS使用錢包管理密鑰:
# cleos wallet create -n scuser Creating wallet: scuser Save password to use in the future to unlock this wallet. Without password imported keys will not be retrievable. "PW5JzRwAUN-----------------------------nAuCRWvHx4XnMPmGf9Kz "
接下來(lái)同樣使用cleos
創(chuàng)建一個(gè)密鑰對(duì):
# cleos create key Private key: 5KZzUHNFNvf------------------------------vuF5z7d29uAUbsdn Public key: EOS63ndkvF-----------------------9ZVcByP9nfZcwMLzbMpn
然后將密鑰保存在之前創(chuàng)建的錢包scuser
中:
# cleos wallet import -n scuser 5KZzUHNFNvf---------------------d29uAUbsdn
還需要?jiǎng)?chuàng)建一個(gè)額外的賬戶進(jìn)行測(cè)試:
# cleos create key Private key: 5JbriTGYsnrpNDvL------------------LgniHVgyTnS5ommxo Public key: EOS8XZoG2248Gu42-------------ps7JoW8tdHQwCsV
然后使用wallet
子命令把這第二個(gè)密鑰也存入錢包:
# cleos wallet import -n scuser 5JbriTGYsnrpND----------HVgyTnS5ommxo
接下來(lái),使用create account
子命令創(chuàng)建一個(gè)賬戶eosio
—— 你需要使用賬戶與EOS區(qū)塊鏈交互:
#./cleos create account eosio scuser EOS63ndkvF---------cByP9nfZcwMLzbMpn EOS8XZo-------wJnieps7JoW8tdHQwCsV
現(xiàn)在使用set contract
子命令部署智能合約:
# cleos set contract scuser /home/centos/sc/ahello Reading WAST/WASM from /home/centos/sc/ahello/ahello.wasm... Using already assembled WASM... Publishing contract... executed transaction: 053a4883d9c191c2754656544dd045da17bd869250af13a00284a613eed3d23b 1792 bytes 601 us # eosio <= eosio::setcode {"account":"scuser","vmtype":0,"vmversion":0,"code":"0061736d01000000013b0c60027f7e006000017e60027e7... # eosio <= eosio::setabi {"account":"scuser","abi":{"types":[],"structs":[{"name":"hi","base":"","fields":[{"name":"user","ty... warning: transaction executed locally, but may not be confirmed by the network yet
合約部署成功后,使用push action
子命令來(lái)執(zhí)行合約方法hi
:
# cleos push action scuser hi '["user1"]' -p scuser executed transaction: 9ed2894aef0f476687ad893ed16594588cc7a813c524d4b8497ba9f50793b151 104 bytes 330 us # scuser <= scuser::hi {"user":"user1"} >> Hello, World user1 warning: transaction executed locally, but may not be confirmed by the network yet
你應(yīng)該可以看到類似下圖的結(jié)果:
以上示例代碼是EOS智能合約的基本模板。 我們現(xiàn)在將逐步分析上面編寫的代碼。
#include#include
上述代碼引入eos智能合約的頭文件。
using namespace eosio;
上述代碼使用eosio作為默認(rèn)命名空間,因此在后續(xù)代碼中可以直接使用諸如 account_name
之類的數(shù)據(jù)類型。
class hello:public eosio :: contract {
創(chuàng)建一個(gè)hello類,繼承自eosio預(yù)置的contract。
public: using contract::contract; /// @abi action
這顯示了指定操作時(shí)在區(qū)塊鏈中實(shí)際執(zhí)行的功能。
void hi( account_name user ) { print( "Hello, World", name{user} ); } }; EOSIO_ABI( hello, (hi) )
EOSIO_ABI是一個(gè)包含以前版本中的apply()
函數(shù)的宏。
感謝各位的閱讀,以上就是“EOS區(qū)塊鏈智能合約開發(fā)方法是什么”的內(nèi)容了,經(jīng)過(guò)本文的學(xué)習(xí)后,相信大家對(duì)EOS區(qū)塊鏈智能合約開發(fā)方法是什么這一問(wèn)題有了更深刻的體會(huì),具體使用情況還需要大家實(shí)踐驗(yàn)證。這里是創(chuàng)新互聯(lián),小編將為大家推送更多相關(guān)知識(shí)點(diǎn)的文章,歡迎關(guān)注!