eosjs代币转账示例【V20版本】

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

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

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

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,它的实例化
需要传入一组交易可能用到的私钥:

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

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

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

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

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

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网络中。

猜你喜欢

转载自blog.csdn.net/mongo_node/article/details/85157872