eosjs转账示例【V20版本】

本文介绍使用V20版本的eosjs实现代币转账的思路,并给出eosjs转账的实现代码。

如果要深入系统地学习Eos上的应用开发,推荐这个教程:Eos智能合约与Dapp开发入门

我们首先在nodejs中引入要使用到的类:

1
2
3
4
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代币:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
const action = {
account: 'eosio.token',
name: 'transfer',
authorization: [{
actor: 'useraaaaaaaa',
permission: 'active',
}],
data: {
from: 'useraaaaaaaa',
to: 'userbbbbbbbb',
quantity: '0.0001 SYS',
memo: '',
},
}

接下来要准备一个签名器对交易进行签名,在开发时,我们可以使用eosj内置的签名器实现 JsSignatureProvider,它的实例化 需要传入一组交易可能用到的私钥:

1
2
3
// useraaaaaaaa的私钥
const defaultPrivateKey = "5JtUScZK2XEp3g9gh7F8bwtPTRAkASmNrrftmx4AxDKD5K4zDnr";
const signatureProvider = new JsSignatureProvider([defaultPrivateKey]);

需要指出的是,JsSignatureProvider没有对私钥的任何保护措施,因此在生产环境中请不要 使用这个签名器。

一旦交易完成签名,就需要利用EOS节点旳RPC接口提交交易,因此接下来初始化一个JsonRpc 对象:

1
const rpc = new JsonRpc('http://127.0.0.1:8888', { fetch });

上述签名、序列化和广播交易的过程在eosjs中由Api类封装,因此我们只需要调用Api实例的transact() 方法即可:

1
2
3
4
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网络中。