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进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。版权声明:如无特殊标注,文章均为本站原创,转载时请以链接形式注明文章出处。
评论