eosjs转账代码怎么写

eosjs转账代码怎么写,相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。

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

我们首先在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智能合约与Dapp开发入门中我们给出了一个基于keosd的签名提供器可供生产环境下使用。

一旦交易完成签名,就需要利用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网络中。

看完上述内容,你们掌握eosjs转账代码怎么写的方法了吗?如果还想学到更多技能或想了解更多相关内容,欢迎关注蜗牛博客行业资讯频道,感谢各位的阅读!

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:niceseo99@gmail.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

评论

有免费节点资源,我们会通知你!加入纸飞机订阅群

×
天气预报查看日历分享网页手机扫码留言评论Telegram