智能合约的编译与ABI

假设写了一个智能合约,比如:store.sol。

希望在此合约部署到以太坊后,用golang来调用此合约相应的方法等。

此时我们可以根据store.sol来生成一个.go文件,此.go文件将包含我们的Go应用程序中和智能合约进行交互的所有可用方法。

那如何由.sol文件,生成.go文件呢?网络上很多教程,只要如下命令行一步即可实现

abigen --sol --pkg=store --out=store.go

或者两步走,先生成abi和bin,再根据abi和bin生成.go文件

solc --abi --bin store.sol

abigen --abi=store.abi --bin=store.bin --pkg=store --out=store.go

但是这方法,只是适用于简单的智能合约。

如果我们的智能合约比较复杂,import了其它的第三方文件,或者第三方智能合约,比如以下的合约,就需要其它方法了。

// Copyright joey network contributors
// SPDX-License-Identifier: (Apache-2.0 AND CC-BY-4.0)
// Code is Apache-2.0 and docs are CC-BY-4.0

pragma solidity ^0.8.0;

import "@openzeppelin/contracts-upgradeable/proxy/utils/Initializable.sol";
import "@openzeppelin/contracts-upgradeable/access/OwnableUpgradeable.sol";

首先,在项目root路径下,新建node_modules目录,在项目root路径执行如下命令,下载所需的第三方文件

npm install @openzeppelin/contracts-upgradeable

npm install @openzeppelin/contracts

这样,就会把依赖的第三方文件下载到项目root路径下的node_modules目录(本例子是用node包来管理的,如果不是,原理也是按项目结构,把依赖按照下载到相应目录)

然后,首先生成abi和bin,注意:solc要求版本比较高,0.8.0不支持,我使用的是0.8.13

solc --include-path ./node_modules/ --base-path . --optimize --bin --abi --overwrite -o ./ store.sol

然后,再根据abi和bin生成.go文件

abigen --abi=store.abi --bin=store.bin --pkg=store --type=Store --out=store.go

注意:--type=Store,指定了生成的.go文件中的合约struct的名字;如果没有--type参数,合约struct的名字缺省就是--pkg的值。

  • 2
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值