假设写了一个智能合约,比如: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路径下,下载所需的第三方文件
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的值。
|