本文介绍使用V20版本的eosjs实现代币转账的思路,并给出eosjs转账的实现代码。
我们首先在nodejs中引入要使用到的类:
代码语言:javascript复制const {Api,JsonRpc,RpcError} = require('eosjs')
const JsSignatureProvider = require('eosjs/dist/eosjs-jssig');
const fetch = require('node-fetch');
const { TextEncoder, TextDecoder } = require('util');
在EOS中,代币转账就是对代币合约的transfer()
方法的调用,因此接下来就是准备一个对代币合约的动作调用。例如,下面的动作将从账号useraaaaaaaa向账号userbbbbbbbb转0.0001个SYS代币:
const action = {
account: 'eosio.token',
name: 'transfer',
authorization: [{
actor: 'useraaaaaaaa',
permission: 'active',
}],
data: {
from: 'useraaaaaaaa',
to: 'userbbbbbbbb',
quantity: '0.0001 SYS',
memo: '',
},
}
接下来要准备一个签名器对交易进行签名,在开发时,我们可以使用eosj内置的签名器实现 JsSignatureProvider,它的实例化需要传入一组交易可能用到的私钥:
代码语言:javascript复制// useraaaaaaaa的私钥
const defaultPrivateKey = "5JtUScZK2XEp3g9gh7F8bwtPTRAkASmNrrftmx4AxDKD5K4zDnr";
const signatureProvider = new JsSignatureProvider([defaultPrivateKey]);
需要指出的是,JsSignatureProvider没有对私钥的任何保护措施,因此在生产环境中请不要使用这个签名器。在教程Eos智能合约与Dapp开发入门中我们给出了一个基于keosd的签名提供器可供生产环境下使用。
一旦交易完成签名,就需要利用EOS节点旳RPC接口提交交易,因此接下来初始化一个JsonRpc对象:
代码语言:javascript复制const rpc = new JsonRpc('http://127.0.0.1:8888', { fetch });
上述签名、序列化和广播交易的过程在eosjs中由Api类封装,因此我们只需要调用Api实例的transact()方法即可:
代码语言:javascript复制const api = new Api({ rpc, signatureProvider, textDecoder: new TextDecoder(), textEncoder: new TextEncoder() });
api.transact({actions:[action]})
.then(ret => console.log(ret))
.catch(err => console.log(err))
在transact()
方法的实现中,将调用JsonRpc对象的push_transaction()方法将签名后的序列化交易提交到节点并广播到整个EOS网络中。