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

目录

1. geth 简介

1.1 下载地址:

1.2 安装:

1.3 查看是否安装成功

2. geth命令介绍

3. geth常用命令

3.1 指定数据目录 --datadir

3.2 账户相关

3.3 控制台console:

3.4 删除数据:

3.5 help

3.6 常见错误

4. Go语言调用合约

4.1 启动rpc端口

4.2 Go调用以太坊

4.3 调用接口

net_version

net_listening

net_peerCount

eth接口

personal接口

db接口

最后

geth


以太坊智能合约开发中最常用的命令行工具。

Geth是由以太坊基金会提供的官方客户端软件,用Go编程语言编写的。Geth提供了一个交互式命令控制台,通过命令控制台中包含了以太坊的各种功能(API)。全名go-ethereum。


1. geth 简介

1.1 下载地址:

官网(很慢):https://geth.ethereum.org/downloads/


国内镜像:https://ethfans.org/wikis/Ethereum-Geth-Mirror


1.2 安装:

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


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

下载下来之后,会在安装目录生成geth.exe

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

将这个文件放在gopath的bin目录中,

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


放在这里就行了


1.3 查看是否安装成功

geth version

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

如果你安装了,但是没有显示这个的话,可能是因为你的系统环境里面没有go的路径,把go的bin目录路径放在系统变量的path就好了~


2. geth命令介绍

geth -help查看帮助

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

命 令:geth [选项] 命令 [命令选项] [参数…]

命令参数介绍:超详细


3. geth常用命令

3.1 指定数据目录 --datadir

如:geth --datadir “路径” account new

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


3.2 账户相关

查看账户:geth account list


查看账户的信息

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


创建账户:geth account new

然后输入两次密码

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


更新指定账户:geth account update "用户地址"


输入账户密码及确认密码


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



默认是会把用户的账户信息存放在这个目录


导入账户:geth account import 你的私钥文件路径(导出私钥存放到xx.txt)

指定保存路径的创建用户:geth --datadir account new

3.3 控制台console:

启动并进入交互式javascript环境


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


默认连接的是ipc

geth attach http://IP:8545,默认不开启

geth attach ws://IP:8546,默认不开启

进入控制台:geth console 可以指定--datadir "路径"

退出控制台:exit 或者 ctrl+d


常用api:


获取区块号:eth.blockNumber


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

是否在监听端口 net.listening

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


开始挖矿:miner.start()

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


挖矿还可以指定进程数:miner.start(1)


停止挖矿:miner.stop()


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


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


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


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


创建用户:personal.newAccount(“12345678”)


设置挖矿账户:miner.setEtherbase(“地址A”)


账户间转钱:eth.sendTransation({from:“地址A”,to:“地址B”,value:web3.toWei(10,“ether”)})


获取交易信息:eth.getTransaction(‘地址A’)


3.4 删除数据:

不要直接删除datadir目录,使用removedb


geth --datadir "路径" removedb

这会删除路径/geth/chaindata,其他东西都不会动,不会删除用户。


3.5 help

geth account -h

geth account help new 查看子命令

3.6 常见错误

1 . Error: authentication needed: password or unlock undefined:


这种报错解锁下账户即可

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

2 . Returned error: exceeds block gas limit:


出现这种错误就看块号的gaslimit,部署时改成一直

获取块号:eth.blockNumber,

根据块号获取详细信息:eth.getBlock(0)

4. Go语言调用合约

4.1 启动rpc端口

geth --datadir "fanone" --identity "fanone" --rpc --rpcport 8545  --rpcapi "db,eth,net,web3,personal" --rpccorsdomain "*" console


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


–identity “fanone”:节点身份标识


–rpc:开启 RPC 接口


–rpcport:RPC 端口,默认go是8545


–rpcapi “db,eth,net,web3”:提供给别人使用的 RPC API,默认为web3接口


–rpccorsdomain:设置能连接到你的节点的 URL,用来完成RPC任 务。* 指任何URL都能连接到,默认只能自己连接


–datadir:区块数据文件夹 ,如果不指定的话,就是上面的那个在C盘的地址。


为了C盘着想,所以还是建议这样,新建一个文件夹放在其他盘


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


就会在这里进行存放了


–networkid:net_version的id


–port:用来监听其他节点的端口


–nodiscover:你的节点不会被其他人发现,除非他们手动添加你

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

是连接这个url


4.2 Go调用以太坊

下载包:"github.com/ethereum/go-ethereum/rpc"

示例代码:

client, _ := rpc.Dial("http://localhost:8545")
var result bool
client.Call(&result ,"net_listening") 
// 注意这里必须使用指针,否则会报空指针异常


启动之后

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

在go中调用

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

4.3 调用接口

net_version

当前连接网络的ID


net_version: 当前连接网络的ID


var networkid string
client.Call(&networkid,"net_version")


networkid:
    "1":Mainnet
    "2": Morden Testnet
    "3": Ropsten Testnet
    "4": Rinkeby Testnet
    "42": Kovan Testnet


在启动rpc服务接口的时候可以指定: --networkid


net_listening

客户端是否处于监听状态

var is_listing bool
client.Call(&is_listing,"net_listening")

net_peerCount

所连接对端节点旳数量

var count string
client.Call(&count,"net_peerCount")
//"0x0" 表示0个
//"0x2" 表示2个


eth接口

1 .eth_accounts:账户地址数组

var accounts []string
client.Call(&accounts,"eth_accounts")

2 .eth_getBalance:获取指定地址账户的余额,单位:wei

var balance string
client.Call(&balance,"eth_getBalance","0x558c90c05d8c4b55a87de03bd601fd76faf50f9b","latest")


参数:

账户地址

整数块编号,或者字符串"latest", “earliest” 或 “pending”

3 .eth_gasPrice:返回当前的gas价格,单位:wei。

var gas_price string
client.Call(&gas_price,"eth_gasPrice")

4.eth_coinbase:


获取挖矿账户地址

var proto_version string
client.Call(&proto_version , "eth_protocolVersion")

5.eth_protocolVersion:


返回当前以太坊协议的版本。


var proto_version string
client.Call(&proto_version , "eth_protocolVersion")

6.eth_mining:


客户端是否在挖矿中


var is_mining bool
client.Call(&is_mining,"eth_mining")

7.eth_hashrate:


返回节点挖矿时每秒可算出的哈希数量。


var hashrate string
client.Call(&hashrate,"eth_hashrate")

8.eth_getTransactionCount:


返回指定地址发生的交易数量


var transactionCount string
client.Call(&transactionCount,"eth_getBalance","0x72w12d05d8c4b55a87de03bd601fd76faf50f9b","latest")
//参数
//    账户地址
//    整数块编号,或者字符串"latest", "earliest" 或 "pending"

9.eth_blockNumber:获取节点当前块编号

var blockNum string
client.Call(&blockNum ,"eth_blockNumber")

personal接口

1 .personal_listAccounts:

获取该节点下的所有账户,和eth_accounts效果一样


var accounts []string
client.Call(&accounts,"personal_listAccounts")

2.personal_newAccount:

创建用户


var newAccount string
client.Call(&newAccount, "personal_newAccount", "12345678")
参数:
    密码

3.personal_lockAccount:


锁定指定账户

var is_lock bool
client.Call(&is_lock, "personal_lockAccount", "账户地址")

//参数:
//    账户地址

4.personal_unlockAccount:


解锁指定账户,有些操作必须解锁账户才可以操作

var is_unlock bool
client.Call(&is_unlock, "personal_lockAccount", "账户地址","账户密码")
参数:
    账户地址
    账户密码

db接口

1.db_putString:


在本地数据库中存入字符串

var is_ok bool
client.Call(&is_ok, "db_putString", "db_name","key",""value")
参数:
    数据库名称
    key名
    要存入的字符串值

2.db_getString:


从本地数据库读取字符串。


var val string
client.Call(&val, "db_getString", "db_name","key")

//参数:
  //  数据库名称
  //  key名


上一篇:【智能合约】Go语言调用智能合约 | geth


下一篇:SpringSecurity之RememberMe实现