您好,登錄后才能下訂單哦!
本篇內容主要講解“在CentOS中怎么怎么實現EOS智能合約”,感興趣的朋友不妨來看看。本文介紹的方法操作簡單快捷,實用性強。下面就讓小編來帶大家學習“在CentOS中怎么怎么實現EOS智能合約”吧!
EOS智能合約的開發需要使用llvm
和abigen
來生成abi
文件。 為此eos提供了一個 名為eosiocpp
的工具。 在這篇文章中,我們介紹如何使用這個工具來開發、部署并調用 一個EOS版本的hello world
智能合約。
首先,編寫一個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()
函數的宏。
到此,相信大家對“在CentOS中怎么怎么實現EOS智能合約”有了更深的了解,不妨來實際操作一番吧!這里是億速云網站,更多相關內容可以進入相關頻道進行查詢,關注我們,繼續學習!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。