go語言區(qū)塊鏈學習調用智能合約
1. 獲取abi文件
合約的接口
在remix工具中編譯合約后,會有一個abi,復制

然后新建一個xx.abi文件,把賦值的粘貼到里面

注意:代碼變了,重新編譯后abi也會變,所以一定要用最新的abi
也可以通過solc生成abi:
solc --bin test.sol -o test.abi
2. 安裝abigen工具
用來生成go文件,
下載文件:github地址


找到這個main.go文件,進行go build,生成abigen.exe文件。

然后放在bin目錄下的這里

然后就可以在這里驗證了

使用abigen工具生成go文件
abigen --abi xx.abi --pkg packagename --type structname --out xx.go
abi 文件在 remix 部署時可以得到pkg 指定輸出文件的包名,也就是package 名稱type 指定合約結構體名稱out 指定輸出go文件名稱

3. remix連接私有鏈
geth啟動私鏈,要指定rpccorsdomain *,不然在remix中是連接不上的。

選擇Web3 Provider方式,默認連接私有鏈8545端口

但是可以看到我們這里是沒有account的

所以我們可以創(chuàng)建一個account

創(chuàng)建了兩個之后

就可以在這里看見了。
4. 合約部署
1.連接私有鏈:選擇Web3 Provider,默認端口號時8545,如果geth啟動的rpc端口號不一致,改成一致
2.部署合約
可能會出現下面幾種錯誤,依此列出解決辦法
1 .Error: authentication needed: password or unlock:這種報錯解鎖下賬戶即可
賬戶解鎖:personal.unlockAccount(“賬戶地址”)

unlock一下就行了

2 .Returned error: exceeds block gas limit:出現這種錯誤就看塊號的gaslimit,部署時改成一直
獲取塊號:eth.blockNumber
根據塊號獲取詳細信息:eth.getBlock(0) 會看到gasLimit的值,在部署時的gaslimit不能大于這個


3 .Returned error: insufficient funds for gas * price + value:部署合約需要手續(xù)費,得賺取,通過挖礦

沒錢, 要挖礦賺錢。

開啟指定線程數挖礦:miner.start(1)
停止挖礦:miner.stop()
檢查是否在挖礦:eth.mining true:在挖礦,false:不在挖礦
獲取賬戶地址數組:eth.accounts
獲取挖礦地址:eth.coinbase 默認第一個創(chuàng)建的賬戶
查看第一個賬戶余額:eth.getBalance(eth.accounts[0])
獲取指定賬戶的余額:eth.getBalance(“賬戶地址”)

5. 初始化私有鏈節(jié)點創(chuàng)世塊
新建一個genesis.json文件,內容如下
{
"config":{
"chainId":15,
"homesteadBlock":0,
"eip155Block":0,
"eip158Block":0
},
"coinbase":"0x0000000000000000000000000000000000000000",
"difficulty":"0x40000",
"extraData":"",
"gasLimit":"0xffffffff",
"nonce":"0x0000000000000042",
"mixhash":"0x0000000000000000000000000000000000000000000000000000000000000000",
"parentHash":"0x0000000000000000000000000000000000000000000000000000000000000000",
"timestamp":"0x00",
"alloc":{
}
}
含義:
coinbase:挖礦賬戶地址,隨便填,后面可以設置,一般默認第一個創(chuàng)建的用戶
difficulty: 設置當前區(qū)塊的難度,如果難度過大,cpu挖礦就很難,這里設置較小難度
gasLimit: 該值設置對GAS的消耗總量限制,用來限制區(qū)塊能包含的交易信息總和,填最大即可。
nonce: nonce就是一個64位隨機數,用于挖礦,注意他和mixhash的設置需要滿足以太坊的Yellow paper
mixhash:與nonce配合用于挖礦,由上一個區(qū)塊的一部分生成的hash。
parentHash: 上一個區(qū)塊的hash值,因為是創(chuàng)世塊,所以這個值是0extraData:
timestamp: 設置創(chuàng)世塊的時間戳
alloc: 用來預置賬號以及賬號的以太幣數量,因為私有鏈挖礦比較容易,所以我們不需要預置有幣的賬號,需要的時候自己創(chuàng)建即可以。
cmd進入到存放json文件的路徑
geth -datadir "fanone" init genesis.json



6. 合約部署
部署時候需要支付手續(xù)費
http://ethscan.hubwiz.com/
7. 調用
github.com/ethereum/go-ethereum v1.10.0
package main
import (
"github.com/ethereum/go-ethereum/ethclient"
"github.com/ethereum/go-ethereum/common"
"eth_block/utils/contract/abi"
"fmt"
"github.com/ethereum/go-ethereum/accounts/abi/bind"
)
func main() {
// 連接rpc
client,err := ethclient.Dial("http://127.0.0.1:8545")
// 定義要操作合約的賬戶地址
addr := "0x29794ab2ed6c47faff7ebdd6dcdd71a263e25460"
// 將字符串地址轉為common.Address
common_addr := common.HexToAddress(addr)
if err != nil {
panic("連接以太坊合約出錯")
}
// 創(chuàng)建合約對象
contract_obj,err11 := contract.NewTestAddress(common_addr,client)
if err11 !=nil {
panic("創(chuàng)建合約對象出錯")
}
fmt.Println(contract_obj.TestAddressCaller) // Caller訪問函數
fmt.Println(contract_obj.TestAddressTransactor) // Transactor 有函數
fmt.Println(contract_obj.TestAddressFilterer) // 沒什么作用
}
以上就是go語言區(qū)塊鏈學習調用智能合約的詳細內容,更多關于go語言區(qū)塊鏈調用智能合約的資料請關注腳本之家其它相關文章!
相關文章
解決Golang中goroutine執(zhí)行速度的問題
這篇文章主要介紹了解決Golang中goroutine執(zhí)行速度的問題,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2021-05-05

