智能合约的编译与ABI

智能合约的编译与ABI,第1张

假设写了一个智能合约,比如: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的值。

欢迎分享,转载请注明来源:内存溢出

原文地址: https://outofmemory.cn/zaji/925164.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-05-16
下一篇 2022-05-16

发表评论

登录后才能评论

评论列表(0条)

保存