【智能合约】Go语言调用智能合约 | geth

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

目录

1. 获取abi文件

2. 安装abigen工具

3. remix连接私有链

4. 合约部署

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

6. 合约部署

7. 调用

1. 获取abi文件

合约的接口


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

image.png

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


image.png


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


也可以通过solc生成abi:


solc --bin test.sol -o test.abi


2. 安装abigen工具

用来生成go文件,


下载文件:github地址


image.png



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

image.png

然后放在bin目录下的这里

image.png

然后就可以在这里验证了

image.png

使用abigen工具生成go文件


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


abi 文件在 remix 部署时可以得到

pkg 指定输出文件的包名,也就是package 名称

type 指定合约结构体名称

out 指定输出go文件名称

image.png


3. remix连接私有链

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

image.png


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

image.png


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

image.png

所以我们可以创建一个account

image.png

创建了两个之后

image.png

就可以在这里看见了。


4. 合约部署

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

2.部署合约


可能会出现下面几种错误,依此列出解决办法

1 .Error: authentication needed: password or unlock:这种报错解锁下账户即可

账户解锁:personal.unlockAccount(“账户地址”)

image.png


unlock一下就行了

image.png


2 .Returned error: exceeds block gas limit:出现这种错误就看块号的gaslimit,部署时改成一直

获取块号:eth.blockNumber

根据块号获取详细信息:eth.getBlock(0) 会看到gasLimit的值,在部署时的gaslimit不能大于这个

image.png


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

image.png


没钱, 要挖矿赚钱。

image.png


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

停止挖矿:miner.stop()

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

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

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

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

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

image.png


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


image.png



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)  // 没什么作用
}
相关文章
|
5月前
|
存储 安全 Java
【Golang】(4)Go里面的指针如何?函数与方法怎么不一样?带你了解Go不同于其他高级语言的语法
结构体可以存储一组不同类型的数据,是一种符合类型。Go抛弃了类与继承,同时也抛弃了构造方法,刻意弱化了面向对象的功能,Go并非是一个传统OOP的语言,但是Go依旧有着OOP的影子,通过结构体和方法也可以模拟出一个类。
299 2
|
7月前
|
Cloud Native 安全 Java
Go:为云原生而生的高效语言
Go:为云原生而生的高效语言
436 1
|
7月前
|
Cloud Native Go API
Go:为云原生而生的高效语言
Go:为云原生而生的高效语言
492 0
|
7月前
|
Cloud Native Java Go
Go:为云原生而生的高效语言
Go:为云原生而生的高效语言
333 0
|
7月前
|
Cloud Native Java 中间件
Go:为云原生而生的高效语言
Go:为云原生而生的高效语言
367 0
|
7月前
|
Cloud Native Java Go
Go:为云原生而生的高效语言
Go:为云原生而生的高效语言
414 0
|
7月前
|
数据采集 Go API
Go语言实战案例:多协程并发下载网页内容
本文是《Go语言100个实战案例 · 网络与并发篇》第6篇,讲解如何使用 Goroutine 和 Channel 实现多协程并发抓取网页内容,提升网络请求效率。通过实战掌握高并发编程技巧,构建爬虫、内容聚合器等工具,涵盖 WaitGroup、超时控制、错误处理等核心知识点。
|
存储 缓存 安全
Go 语言中的 Sync.Map 详解:并发安全的 Map 实现
`sync.Map` 是 Go 语言中用于并发安全操作的 Map 实现,适用于读多写少的场景。它通过两个底层 Map(`read` 和 `dirty`)实现读写分离,提供高效的读性能。主要方法包括 `Store`、`Load`、`Delete` 等。在大量写入时性能可能下降,需谨慎选择使用场景。
|
存储 负载均衡 监控
如何利用Go语言的高效性、并发支持、简洁性和跨平台性等优势,通过合理设计架构、实现负载均衡、构建容错机制、建立监控体系、优化数据存储及实施服务治理等步骤,打造稳定可靠的服务架构。
在数字化时代,构建高可靠性服务架构至关重要。本文探讨了如何利用Go语言的高效性、并发支持、简洁性和跨平台性等优势,通过合理设计架构、实现负载均衡、构建容错机制、建立监控体系、优化数据存储及实施服务治理等步骤,打造稳定可靠的服务架构。
369 1
|
Go 调度 开发者
探索Go语言中的并发模式:goroutine与channel
在本文中,我们将深入探讨Go语言中的核心并发特性——goroutine和channel。不同于传统的并发模型,Go语言的并发机制以其简洁性和高效性著称。本文将通过实际代码示例,展示如何利用goroutine实现轻量级的并发执行,以及如何通过channel安全地在goroutine之间传递数据。摘要部分将概述这些概念,并提示读者本文将提供哪些具体的技术洞见。

热门文章

最新文章