web3.js 调用智能合约写函数
调用智能合约写函数,会改变区块链状态,需要消耗Gas,被视为一种交易操作。
本章将使用web3.js – 部署智能合约 章节中部署好的合约,调用此合约的
set()函数。
调用智能合约写函数的执行步骤与前面章节:web3.js – 交易操作、web3.js – 部署智能合约 涉及到交易操作步骤基本相同,包括:
构建交易对象
签署交易
广播交易
因此我们将使用相同的基本设置,如下所示:
app.js文件
var Tx = require('ethereumjs-tx').Transaction
const Web3 = require('web3')
const web3 = new Web3('https://ropsten.infura.io/YOUR_INFURA_API_KEY')
const account1 = '' // Your account address 1
const account2 = '' // Your account address 2
const privateKey1 = Buffer.from('YOUR_PRIVATE_KEY_1', 'hex')
const privateKey2 = Buffer.from('YOUR_PRIVATE_KEY_2', 'hex')
构建交易对象
如下所示,构建交易对象:
const txObject = {
nonce: web3.utils.toHex(txCount),
gasLimit: web3.utils.toHex(800000),
gasPrice: web3.utils.toHex(web3.utils.toWei('10', 'gwei')),
to: contractAddress,
data: data
}
nonce、
gasLimit、
gasPrice的使用,与前面章节基本相同,不再赘述。剩下2个参数说明如下:
to – 此参数将是已部署智能合约的地址。可以从etherscan中获取。
data – 被调用的智能合约函数的十六进制表示。
const contractAddress = '0x30951343d6d80d2c94897f1a81c53cc030aef879'
const contractABI = [
{
"constant": false,
"inputs": [
{
"internalType": "string",
"name": "_value",
"type": "string"
}
],
"name": "set",
"outputs": [],
"payable": false,
"stateMutability": "nonpayable",
"type": "function"
},
{
"constant": true,
"inputs": [],
"name": "get",
"outputs": [
{
"internalType": "string",
"name": "",
"type": "string"
}
],
"payable": false,
"stateMutability": "view",
"type": "function"
},
{
"inputs": [],
"payable": false,
"stateMutability": "nonpayable",
"type": "constructor"
}
]
const contract = new web3.eth.Contract(contractABI, contractAddress)
关于
data参数,可以使用web3.js函数
encodeABI(),把contract对象中的智能合约函数转换为十六进制表示。如下所示:
const data = contract.methods.set("qikegu").encodeABI()
至此我们已经完成了准备工作,接下来就要执行调用了。
章节
web3.js – 执行写函数调用