EOS智能合約的開發需要使用
llvm
和
abigen
來生成
abi
檔案。 為此eos提供了一個 名為
eosiocpp
的工具。 在這篇文章中,我們介紹如何使用這個工具來開發、部署并調用 一個EOS版本的
hello world
智能合約。
這篇文章的代碼是在CentOS完成的,但在EOS支援的其他linux發行版上應該也沒有問題。 如果你同時也對以太坊開發感興趣,可以 通路我們的入門級的以太坊教程 以及更進階的以太坊電商實戰教程。
智能合約撰寫
首先,編寫一個ahello.cpp檔案 - EOS的合約開發使用C++語言:
# mkdir /home/centos/sc/ahello
# cd /home/centos/sc/ahello
# vim ahello.cpp
将以下内容插入到ahello.cpp檔案中:
#include <eosiolib/eosio.hpp>
#include <eosiolib/print.hpp>
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) )
接下來,編譯并建立一個wast(web程式集)檔案和一個abi檔案。
# eosiocpp -o ahello.wast ahello.cpp
# eosiocpp -g ahello.abi ahello.cpp
智能合約的部署與互動
在部署合約之前,我們需要建立測試用的錢包、密鑰和帳戶。
首先,使用EOS用戶端
cleos
建立一個名為
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 "
接下來同樣使用
cleos
建立一個密鑰對:
# cleos create key
Private key: 5KZzUHNFNvf------------------------------vuF5z7d29uAUbsdn
Public key: EOS63ndkvF-----------------------9ZVcByP9nfZcwMLzbMpn
然後将密鑰儲存在之前建立的錢包
scuser
中:
# cleos wallet import -n scuser 5KZzUHNFNvf---------------------d29uAUbsdn
還需要建立一個額外的賬戶進行測試:
# cleos create key
Private key: 5JbriTGYsnrpNDvL------------------LgniHVgyTnS5ommxo
Public key: EOS8XZoG2248Gu42-------------ps7JoW8tdHQwCsV
然後使用
wallet
子指令把這第二個密鑰也存入錢包:
# cleos wallet import -n scuser 5JbriTGYsnrpND----------HVgyTnS5ommxo
接下來,使用
create account
子指令建立一個賬戶
eosio
—— 你需要使用賬戶與EOS區塊鍊互動:
#./cleos create account eosio scuser EOS63ndkvF---------cByP9nfZcwMLzbMpn EOS8XZo-------wJnieps7JoW8tdHQwCsV
現在使用
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
子指令來執行合約方法
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
你應該可以看到類似下圖的結果:

代碼分析
以上示例代碼是EOS智能合約的基本模闆。 我們現在将逐漸分析上面編寫的代碼。
#include <eosiolib/eosio.hpp>
#include <eosiolib/print.hpp>
上述代碼引入eos智能合約的頭檔案。
using namespace eosio;
上述代碼使用eosio作為預設命名空間,是以在後續代碼中可以直接使用諸如
account_name
之類的資料類型。
class hello:public eosio :: contract {
建立一個hello類,繼承自eosio預置的contract。
public:
using contract::contract;
/// @abi action
這顯示了指定操作時在區塊鍊中實際執行的功能。
void hi( account_name user ) {
print( "Hello, World", name{user} );
}
};
EOSIO_ABI( hello, (hi) )
EOSIO_ABI是一個包含以前版本中的
apply()
函數的宏。
在這篇文章中,我們介紹了如何編寫一個EOS版本的Hellow World智能合約,希望 有助于你初步了解EOS智能合約的開發。
原文:開發第一個EOS智能合約
版權聲明:本文為CSDN部落客「weixin_34224941」的原創文章,遵循CC 4.0 BY-SA版權協定,轉載請附上原文出處連結及本聲明。
原文連結:https://blog.csdn.net/weixin_34224941/article/details/92411502