BSN智能合約開發培訓-XuperChain(四)

百度超級鏈XuperChain是一個支持多語言合約的區塊鏈框架,有多種語言來供大家選擇使用開發智能合約。目前超級鏈的智能合約可以使用C++ 或者 Go 語言來編寫,理論上任何可以編譯成Wasm字節碼的語言都可以用來編寫超級鏈的智能合約。C++ 合約相對Go合約性能會更好些,go合約在易用性上更好,開發者可以根據需要選擇自己喜歡的語言來編寫智能合約,這篇文章會通過一步步的指引來幫助大家使用C++ 或者Go來編寫超級鏈的智能合約。下面的內容將按照步驟拆解,手把手教你如何順利完成智能合約的編寫,部署和測試,耐心讀完本文相信你會對超級鏈智能合約建立完整認知,快速get新技能。

1. 準備工作

1.1?環境要求

目前超級鏈節點主要運行在linux和mac上,windows不能運行超級鏈節點。

1.?go >= 1.12.x && <= 1.13.x

2.?g++ >= 4.8.2 或者 clang++ >= 3.3

3.?Docker

1.2?下載編譯XuperChain

智能合約只有部署到鏈上才能運行,因此我們首先要編譯并啟動xuperchain節點。

如果需要使用特定分支,使用git checkout來切換特定分支,如 git checkout v3.7

1.3?設置環境變量

這些環境變量有助于我們更方便的執行一些命令而不用指定命令的全路徑。

1.4?啟動XuperChain

--vm ixvm參數是選擇ixvm合約虛擬機,開發合約過程中使用ixvm虛擬機能加快合約部署

1.5?創建合約賬號

合約賬號用來進行合約管理,比如合約的權限控制等,要部署合約必須創建合約賬號,同時合約賬號里面需要有充足的xuper來部署合約。

創建合約賬號 XC1111111111111111@xuper

給合約賬號轉賬

$ ./xchain-cli transfer --to XC1111111111111111@xuper --amount 100000000

cd26657006f6f75f07bd53ad0a7fe74d76985cd592542d8cc87dc3fcdde115f5

1.6?小結

至此我們完成了所有的準備工作,包括編譯XuperChain,創建鏈,啟動節點,創建合約賬號,后面我們開始體驗怎么編譯,部署和調用智能合約。

2.?快速體驗

在開始編寫智能合約之前首先通過一個簡單的例子來給大家演示合約是如何從代碼到字節碼,以及如何部署到鏈上,如何發起對智能合約的調用。我們使用一個c++合約為例來展示如何編譯、部署、調用合約。

2.1?創建合約工程

xdev工具是隨XuperChain發布的一個合約編譯和測試工具,在編譯完xuperchain之后生成在output目錄。

xdev提供了一個默認的c++合約工程模板

這個命令創建了一個hello-cpp的合約工程

2.2?編譯合約

第一次編譯的時間會長一點,因為xdev需要下載編譯器鏡像,以及編譯超級鏈的標準庫。

編譯結果為hello.wasm,后面我們使用這個文件來部署合約

2.3?部署合約

此命令看起來很長,但是其中很多參數都有默認值,我們先來看一下參數的含義:

? wasm deploy :此為部署wasm合約的命令參數,不做過多解釋

???--account XC1111111111111111@xuper:此為部署wasm合約的賬號(只有合約賬號才能進行合約的部署)

???--cname hello:這里的hello是指部署后在鏈上的合約名字,可以自行命名(但有規則,長度在4~16字符)

??--runtime c 指明我們部署的是一個c++代碼編譯的合約,如果是go合約這里填go即可。

??--fee 為我們部署這個合約所需要的xuper

??最后的hello.wasm是合約編譯好的文件

2.4?調用合約

參數解釋如下:

??wasm invoke 表示我們要調用一個合約

??--method hello 表示我們要調用合約的hello方法

??--fee 指明我們這次調用合約花費的xuper

??最后的參數指明我們調用的合約名字hello

2.5?小結

通過本節的學習,我們快速掌握了如果編譯,部署和調用合約,在下面的章節里面我們學些如果使用C++或者Go語言來編寫智能合約。

3.?合約編寫詳解

XuperChain目前主要支持兩種編譯成wasm格式的合約語言,c++和go,合約框架的整體結構是一致的,在不同語言上的表現形式不太一樣,但熟悉一種語言的SDK之后很容易遷移到其他語言。

下面大概說明如何編寫這兩種類型的合約

3.1 C++合約

以counter合約為例來看如何編寫一個C++合約。

3.1.1?合約樣例

代碼在contractsdk/cpp/example/counter.cc

3.1.2?代碼解析

下面我們逐行解析合約代碼:

??#include <xchain/xchain.h>為必須的,里面包含了編寫合約所需要的庫。

? struct Counter : public xchain::Contract {}; 聲明了我們的合約類,所有的合約類都要繼承自xchain::Contract。

? DEFINE_METHOD(Counter, initialize) 我們通過DEFINE_METHOD來為合約類定義合約方法,在這個例子里面我們為Counter類定義了一個叫initialize的合約方法。

? xchain::Context* ctx = self.context();用來獲取合約的上下文,每個合約都有一個對應的合約執行上下文,通過上下文我們可以獲取合約參數,寫入合約數據,context對象是我們經常要操作的一個對象。

? const std::string& creator = ctx->arg("creator");,用于從合約上下文里面獲取合約方法的參數,這里我們獲取了名字叫creator的合約參數,合約的參數列表是一個map結構, key為合約參數的名字,value為參數對應的用戶傳遞的值。

? ctx->put_object("creator", creator); 通過合約上下文的put_object方法,我們可以向鏈上寫入數據。

? ctx->ok("initialize succeed"); 用于返回合約的執行結果,如果合約執行失敗則調用ctx->error。

通過上面的代碼分析我們得到了如下知識

??一個合約有多個方法組成,如counter合約的initialize,increase, get方法。

? initialize是每個合約必須實現的方法,這個合約方法會在部署合約的時候自動執行。

??每個合約方法有一個Context對象,通過這個對象我們能獲取到很多有用的方法,如獲取用戶參數等。

??通過Context對象的ok或者error方法我們能給調用方反饋合約的執行情況:成功或者失敗。

更多的c++語言合約例子在超級鏈項目的core/contractsdk/cpp/example里面尋找。

3.2 Go合約

以counter合約為例來看如何編寫一個go合約。

3.2.1?合約樣例

代碼在contractsdk/go/example/counter/counter.go

go合約的整體框架結構跟c++合約一樣,在表現形式上稍微有點不一樣:

??c++合約使用DEFINE_METHOD來定義合約方法,go通過結構體方法來定義合約方法

??c++通過ctx->ok來返回合約數據,go通過返回code.Response對象來返回合約數據

? go合約需要在main函數里面調用driver.Serve來啟動合約。

更多的go語言合約例子在超級鏈項目的core/contractsdk/go/example里面尋找。

3.2.2?合約編譯

Go合約使用如下命令來編譯合約

3.2.3?合約部署

Go合約部署唯一跟c++合約不一樣的地方在于--runtime參數,完整命令如下

Go合約的調用跟c++合約參數一致。

3.3?小結

在這個章節里面我們學習了如何使用c++和go語言來編寫合約,更多的合約例子可以在對應語言SDK的example目錄里面尋找,在下一章節我們學習如果給合約編寫單元測試。

4.?合約單測

如果每次測試合約都需要部署到鏈上再發起調用會特別麻煩,xdev工具提供了單測能力,可以脫離鏈上環境運行合約。

test目錄下放著合約測試文件,文件以 .test.js結尾,可以有多個測試文件。以hello-cpp目錄下的test/hello.test.js為例,文件內容如下:

使用Test函數來定義測試case,hello為測試名字, 匿名js function作為測試的body。全局對象xchain是我們跟xchain環境打交道的入口,xchain.Deploy用來部署一個合約到xchain環境,返回的contract對象,調用contract.Invoke方法即可調用合約。Deploy和Invoke方法都是通過拋出異常的方式來處理錯誤,測試框架會自動捕獲錯誤來結束測試case。t.Run可以定義子測試case。

使用如下命令來啟動測試

5. VSCode編輯器集成

配置編譯和測試task

為了方便在vscode里面編譯和測試合約,在.vscode/tasks.json里面添加如下內容

編譯合約

Run Build Task(??B)來啟動構建

跑合約單測

調用Run Task命令之后,選擇xdev test來觸發單元測試

代碼補全

為了讓vscode幫我們自動補全代碼,需要做如下配置,在項目的.vscode/settings.json文件里面加上這一個配置

之后就能用vscode的自動補全功能了.

6.?開放網絡集成環境

超級鏈開放網絡是基于百度自研底層技術搭建的區塊鏈基礎服務網絡,符合中國標準,超級節點遍布全國,區塊鏈網絡完全開放,為用戶提供區塊鏈快速部署和運行的環境,最低2元錢就用上的區塊鏈服務,讓信任鏈接更加便利。

超級鏈開放網絡為開發者提供了合約開發、編譯、部署、管理的一站式可視化集成環境,下面介紹如何在開放網絡上開發部署智能合約。

6.1?賬戶注冊

1. 在超級鏈官網https://xchain.baidu.com/使用百度賬號登錄,如果沒有百度賬號請先注冊。

2. 進入超級鏈開放網絡控制臺,第一次登錄的用戶,平臺會為用戶創建區塊鏈賬戶,請按照創建賬戶指引文檔完成安全碼設置,并記錄自己的助記詞和私鑰。

3.?????????

6.2?創建合約賬戶

1.?在工作臺,選擇「開放網絡 —> 合約管理」,點擊「創建合約賬戶」

2.?進入創建合約賬戶頁,輸入安全碼后點擊「確認創建」,系統自動生成賬戶名稱后,即創建完畢

3.??????????

6.3?合約開發和部署

1.?在工作臺,選擇「開放網絡 —> 合約管理」,點擊「創建智能合約」

2. 進入新頁面,按要求填寫基本信息、編輯合約代碼,編譯成功后點擊「安裝」,即可進入合約安裝(部署)流程。合約代碼編譯有兩種方式:

??模板合約;選擇模板后,只需在模板代碼中填寫相關參數即可(參考模板詳情完成參數填寫)

??自定義合約;在編輯器內完成C++語言的合約編輯即可

?????????

3. 進入安裝流程,用戶需按合約代碼完成預執行操作。點擊「開始驗證」,執行通過會進入安裝確認頁

??模板合約;系統會提供模板的函數,只需填寫參數即可(可參考模板詳情)

??自定義合約;根據頁面操作說明,完成函數、參數填寫

? ??

4. 進入確認安裝頁,頁面顯示安裝合約預計消耗的余額。點擊「安裝合約」將合約上鏈,上鏈過程需要等待10S左右。安裝完成后,在合約管理列表中可看到合約狀態變更為‘安裝成功’,即該合約已完成安裝。

6.4?合約調用

目前開放網絡支持通過Go和Javascript兩種SDK調用智能合約。

? Go SDK:

https://github.com/xuperchain/xuper-java-sdk

? Javascript SDK:

https://github.com/xuperchain/xuper-sdk-js

7.?結語

以上就是關于如何編寫超級鏈智能合約的錦囊秘籍,可以助你從小白秒變資深區塊鏈開發者。百度超級鏈正在聯合BSN舉辦區塊鏈創新開發者大賽,現在基于百度超級鏈編寫智能合約將有機會獲得萬元大獎,免費享受專業的區塊鏈開發培訓,點擊閱讀原文速去報名吧!

來源:百度超級鏈

最后編輯于
?著作權歸作者所有,轉載或內容合作請聯系作者
平臺聲明:文章內容(如有圖片或視頻亦包括在內)由作者上傳并發布,文章內容僅代表作者本人觀點,簡書系信息發布平臺,僅提供信息存儲服務。
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市,隨后出現的幾起案子,更是在濱河造成了極大的恐慌,老刑警劉巖,帶你破解...
    沈念sama閱讀 230,622評論 6 544
  • 序言:濱河連續發生了三起死亡事件,死亡現場離奇詭異,居然都是意外死亡,警方通過查閱死者的電腦和手機,發現死者居然都...
    沈念sama閱讀 99,716評論 3 429
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人,你說我怎么就攤上這事。” “怎么了?”我有些...
    開封第一講書人閱讀 178,746評論 0 383
  • 文/不壞的土叔 我叫張陵,是天一觀的道長。 經常有香客問我,道長,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 63,991評論 1 318
  • 正文 為了忘掉前任,我火速辦了婚禮,結果婚禮上,老公的妹妹穿的比我還像新娘。我一直安慰自己,他們只是感情好,可當我...
    茶點故事閱讀 72,706評論 6 413
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著,像睡著了一般。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發上,一...
    開封第一講書人閱讀 56,036評論 1 329
  • 那天,我揣著相機與錄音,去河邊找鬼。 笑死,一個胖子當著我的面吹牛,可吹牛的內容都是我干的。 我是一名探鬼主播,決...
    沈念sama閱讀 44,029評論 3 450
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了?” 一聲冷哼從身側響起,我...
    開封第一講書人閱讀 43,203評論 0 290
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后,有當地人在樹林里發現了一具尸體,經...
    沈念sama閱讀 49,725評論 1 336
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內容為張勛視角 年9月15日...
    茶點故事閱讀 41,451評論 3 361
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發現自己被綠了。 大學時的朋友給我發了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 43,677評論 1 374
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖,靈堂內的尸體忽然破棺而出,到底是詐尸還是另有隱情,我是刑警寧澤,帶...
    沈念sama閱讀 39,161評論 5 365
  • 正文 年R本政府宣布,位于F島的核電站,受9級特大地震影響,放射性物質發生泄漏。R本人自食惡果不足惜,卻給世界環境...
    茶點故事閱讀 44,857評論 3 351
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧,春花似錦、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 35,266評論 0 28
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至,卻和暖如春,著一層夾襖步出監牢的瞬間,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 36,606評論 1 295
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人。 一個月前我還...
    沈念sama閱讀 52,407評論 3 400
  • 正文 我出身青樓,卻偏偏與公主長得像,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當晚...
    茶點故事閱讀 48,643評論 2 380

推薦閱讀更多精彩內容