目录
  • 1. 获取abi文件
    • 合约的接口
  • 2. 安装abigen工具
    • 3. remix连接私有链
      • 4. 合约部署
        • 5. 初始化私有链节点创世块
          • 6. 合约部署
            • 7. 调用

              1. 获取abi文件

              合约的接口

              在remix工具中编译合约后,会有一个abi,复制

              go语言区块链学习调用智能合约

              然后新建一个xx.abi文件,把赋值的粘贴到里面

              go语言区块链学习调用智能合约

              注意:代码变了,重新编译后abi也会变,所以一定要用最新的abi

              也可以通过solc生成abi:

              solc –bin test.sol -o test.abi

              2. 安装abigen工具

              用来生成go文件,

              下载文件:github地址

              go语言区块链学习调用智能合约

              go语言区块链学习调用智能合约

              找到这个main.go文件,进行go build,生成abigen.exe文件。

              go语言区块链学习调用智能合约

              然后放在bin目录下的这里

              go语言区块链学习调用智能合约

              然后就可以在这里验证了

              go语言区块链学习调用智能合约

              使用abigen工具生成go文件

              abigen --abi xx.abi --pkg packagename --type structname --out xx.go
              

              abi 文件在 remix 部署时可以得到pkg 指定输出文件的包名,也就是package 名称type 指定合约结构体名称out 指定输出go文件名称

              go语言区块链学习调用智能合约

              3. remix连接私有链

              geth启动私链,要指定rpccorsdomain *,不然在remix中是连接不上的。

              go语言区块链学习调用智能合约

              选择Web3 Provider方式,默认连接私有链8545端口

              go语言区块链学习调用智能合约

              但是可以看到我们这里是没有account的

              go语言区块链学习调用智能合约

              所以我们可以创建一个account

              go语言区块链学习调用智能合约

              创建了两个之后

              go语言区块链学习调用智能合约

              就可以在这里看见了。

              4. 合约部署

              1.连接私有链:选择Web3 Provider,默认端口号时8545,如果geth启动的rpc端口号不一致,改成一致

              2.部署合约

              可能会出现下面几种错误,依此列出解决办法
              1 .Error: authentication needed: password or unlock:这种报错解锁下账户即可
              账户解锁:personal.unlockAccount(“账户地址”)

              go语言区块链学习调用智能合约

              unlock一下就行了

              go语言区块链学习调用智能合约

              2 .Returned error: exceeds block gas limit:出现这种错误就看块号的gaslimit,部署时改成一直
              获取块号:eth.blockNumber
              根据块号获取详细信息:eth.getBlock(0) 会看到gasLimit的值,在部署时的gaslimit不能大于这个

              go语言区块链学习调用智能合约

              go语言区块链学习调用智能合约

              3 .Returned error: insufficient funds for gas * price + value:部署合约需要手续费,得赚取,通过挖矿

              go语言区块链学习调用智能合约

              没钱, 要挖矿赚钱。

              go语言区块链学习调用智能合约

              开启指定线程数挖矿:miner.start(1)

              停止挖矿:miner.stop()

              检查是否在挖矿:eth.mining true:在挖矿,false:不在挖矿

              获取账户地址数组:eth.accounts

              获取挖矿地址:eth.coinbase 默认第一个创建的账户

              查看第一个账户余额:eth.getBalance(eth.accounts[0])

              获取指定账户的余额:eth.getBalance(“账户地址”)

              go语言区块链学习调用智能合约

              5. 初始化私有链节点创世块

              新建一个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:挖矿账户地址,随便填,后面可以设置,一般默认第一个创建的用户

              difficulty: 设置当前区块的难度,如果难度过大,cpu挖矿就很难,这里设置较小难度

              gasLimit: 该值设置对GAS的消耗总量限制,用来限制区块能包含的交易信息总和,填最大即可。

              nonce: nonce就是一个64位随机数,用于挖矿,注意他和mixhash的设置需要满足以太坊的Yellow paper

              mixhash:与nonce配合用于挖矿,由上一个区块的一部分生成的hash。

              parentHash: 上一个区块的hash值,因为是创世块,所以这个值是0extraData:

              timestamp: 设置创世块的时间戳

              alloc: 用来预置账号以及账号的以太币数量,因为私有链挖矿比较容易,所以我们不需要预置有币的账号,需要的时候自己创建即可以。

              cmd进入到存放json文件的路径

              geth -datadir "fanone" init genesis.json
              

              go语言区块链学习调用智能合约

              go语言区块链学习调用智能合约

              go语言区块链学习调用智能合约

              6. 合约部署

              部署时候需要支付手续费

              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("连接以太坊合约出错")
                  }
                  // 创建合约对象
                  contract_obj,err11 := contract.NewTestAddress(common_addr,client)
                  if err11 !=nil {
                      panic("创建合约对象出错")
                  }
                  fmt.Println(contract_obj.TestAddressCaller) // Caller访问函数
                  fmt.Println(contract_obj.TestAddressTransactor) // Transactor 有函数
                  fmt.Println(contract_obj.TestAddressFilterer)  // 没什么作用
              }
              

              以上就是go语言区块链学习调用智能合约的详细内容,更多关于go语言区块链调用智能合约的资料请关注其它相关文章!

              声明:本站所有文章,如无特殊说明或标注,均为本站原创发布。任何个人或组织,在未征得本站同意时,禁止复制、盗用、采集、发布本站内容到任何网站、书籍等各类媒体平台。如若本站内容侵犯了原著者的合法权益,可联系我们进行处理。