Web3.js查询以太币和代币余额及转账

 更新时间:2022年09月20日 10:49:23   作者:JackieDYH  
这篇文章主要介绍了Web3.js查询以太币和代币余额以及转账,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下

安装

npm install web3

web3.js查询以太币及代币余额以及进行以太币和代币转账

在私链和主链上查询以太币及代币余额

查询类方法在私链和主链上的方法都是一样的

主链地址。可以去infura申请

contractAbi。合约的abi。可以去https://etherscan.io获取,如果代币合约提供了code,就会有abi

// 引入web3
var Web3 = require('web3');
if (typeof web3 !== 'undefined') {
    web3 = new Web3(web3.currentProvider);
} else {
    // web3 = new Web3(new Web3.providers.HttpProvider("http://localhost:7545"));
    web3 = new Web3(new Web3.providers.HttpProvider("https://mainnet.infura.io/yourAddress"));
}
 
// 定义合约abi
var contractAbi = [{"constant":true,"inputs":[],"name":"mintingFinished","outputs":[{"name":"","type":"bool"}],"payable":false,"stateMutability":"view","type":"function"},{"constant":true,"inputs":[],"name":"name","outputs":[{"name":"","type":"string"}],"payable":false,"stateMutability":"view","type":"function"},{"constant":false,"inputs":[{"name":"_spender","type":"address"},{"name":"_value","type":"uint256"}],"name":"approve","outputs":[{"name":"","type":"bool"}],"payable":false,"stateMutability":"nonpayable","type":"function"},{"constant":true,"inputs":[],"name":"totalSupply","outputs":[{"name":"","type":"uint256"}],"payable":false,"stateMutability":"view","type":"function"},{"constant":false,"inputs":[{"name":"_from","type":"address"},{"name":"_to","type":"address"},{"name":"_value","type":"uint256"}],"name":"transferFrom","outputs":[{"name":"","type":"bool"}],"payable":false,"stateMutability":"nonpayable","type":"function"},{"constant":true,"inputs":[],"name":"decimals","outputs":[{"name":"","type":"uint8"}],"payable":false,"stateMutability":"view","type":"function"},{"constant":true,"inputs":[],"name":"cap","outputs":[{"name":"","type":"uint256"}],"payable":false,"stateMutability":"view","type":"function"},{"constant":false,"inputs":[],"name":"unpause","outputs":[],"payable":false,"stateMutability":"nonpayable","type":"function"},{"constant":false,"inputs":[{"name":"_to","type":"address"},{"name":"_amount","type":"uint256"}],"name":"mint","outputs":[{"name":"","type":"bool"}],"payable":false,"stateMutability":"nonpayable","type":"function"},{"constant":false,"inputs":[{"name":"_value","type":"uint256"}],"name":"burn","outputs":[],"payable":false,"stateMutability":"nonpayable","type":"function"},{"constant":true,"inputs":[],"name":"paused","outputs":[{"name":"","type":"bool"}],"payable":false,"stateMutability":"view","type":"function"},{"constant":false,"inputs":[{"name":"_spender","type":"address"},{"name":"_subtractedValue","type":"uint256"}],"name":"decreaseApproval","outputs":[{"name":"success","type":"bool"}],"payable":false,"stateMutability":"nonpayable","type":"function"},{"constant":true,"inputs":[{"name":"_owner","type":"address"}],"name":"balanceOf","outputs":[{"name":"balance","type":"uint256"}],"payable":false,"stateMutability":"view","type":"function"},{"constant":false,"inputs":[],"name":"finishMinting","outputs":[{"name":"","type":"bool"}],"payable":false,"stateMutability":"nonpayable","type":"function"},{"constant":false,"inputs":[],"name":"pause","outputs":[],"payable":false,"stateMutability":"nonpayable","type":"function"},{"constant":true,"inputs":[],"name":"owner","outputs":[{"name":"","type":"address"}],"payable":false,"stateMutability":"view","type":"function"},{"constant":true,"inputs":[],"name":"symbol","outputs":[{"name":"","type":"string"}],"payable":false,"stateMutability":"view","type":"function"},{"constant":false,"inputs":[{"name":"_to","type":"address"},{"name":"_value","type":"uint256"}],"name":"transfer","outputs":[{"name":"","type":"bool"}],"payable":false,"stateMutability":"nonpayable","type":"function"},{"constant":false,"inputs":[{"name":"_spender","type":"address"},{"name":"_addedValue","type":"uint256"}],"name":"increaseApproval","outputs":[{"name":"success","type":"bool"}],"payable":false,"stateMutability":"nonpayable","type":"function"},{"constant":true,"inputs":[{"name":"_owner","type":"address"},{"name":"_spender","type":"address"}],"name":"allowance","outputs":[{"name":"","type":"uint256"}],"payable":false,"stateMutability":"view","type":"function"},{"constant":false,"inputs":[{"name":"newOwner","type":"address"}],"name":"transferOwnership","outputs":[],"payable":false,"stateMutability":"nonpayable","type":"function"},{"inputs":[],"payable":false,"stateMutability":"nonpayable","type":"constructor"},{"anonymous":false,"inputs":[{"indexed":true,"name":"burner","type":"address"},{"indexed":false,"name":"value","type":"uint256"}],"name":"Burn","type":"event"},{"anonymous":false,"inputs":[],"name":"Pause","type":"event"},{"anonymous":false,"inputs":[],"name":"Unpause","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"name":"to","type":"address"},{"indexed":false,"name":"amount","type":"uint256"}],"name":"Mint","type":"event"},{"anonymous":false,"inputs":[],"name":"MintFinished","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"name":"owner","type":"address"},{"indexed":true,"name":"spender","type":"address"},{"indexed":false,"name":"value","type":"uint256"}],"name":"Approval","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"name":"from","type":"address"},{"indexed":true,"name":"to","type":"address"},{"indexed":false,"name":"value","type":"uint256"}],"name":"Transfer","type":"event"}];
 
// 合约地址
var contractAddress = "0x7FCCF800568747b178c6cBbe4Bf3d147df75ac61";
 
// 账号
var currentAccount = "0x4e9d5c58d8d6f02FFe5A6EF10CB804FfFB556bBb";
 
// 定义合约
var myContract = new web3.eth.Contract(contractAbi, contractAddress, {
    from: currentAccount, // default from address
    gasPrice: '10000000000' // default gas price in wei, 10 gwei in this case
});
 
// 查询以太币余额
web3.eth.getBalance(currentAccount).then(console.log);
 
// 查看某个账号的代币余额
myContract.methods.balanceOf(contractAddress).call({from: currentAccount}, function(error, result){
    if(!error) {
        console.log(result);
    } else {
        console.log(error);
    }
});

这里还可以查询代币的名称,符号,小数位,发行总量等等,因为代币合约一般都符合ERC标准,都有这些基本方法。甚至如果你有合约代码和abi,还可以调用合约的其他方法,当然调用有些方法需要权限及前置条件

// 获得代币名称
myContract.methods.name().call({from: currentAccount}, function(error, result){
    if(!error) {
          console.log(result);
    } else {
      console.log(error);
    }
});
 
// 获取代币符号
myContract.methods.symbol().call({from: currentAccount}, function(error, result){
    if(!error) {
      console.log(result);
     } else {
      console.log(error);
     }
});
 
// 获取代币总量
myContract.methods.totalSupply().call({from: currentAccount}, function(error, result){
    if(!error) {
      console.log(result);
     } else {
      console.log(error);
     }
});
 
// 查看某个账号允许另一个账号可使用的代币数量
myContract.methods.allowance(sender, spender).call({from: currentAccount}, function(error, result){
    if(!error) {
      console.log(result);
     } else {
      console.log(error);
     }
});

在私链上转账以太币及代币

// 以太币转账
web3.eth.sendTransaction({
    from: currentAccount,
    to: receiverAccount,
    value: '1000000000000000'
})
.then(function(receipt){
    console.log(receipt);
});
 
// 代币转账
myContract.methods.transfer(to, amount).send({from: currentAccount}), function(error, transactionHash){
    if(!error) {
       console.log('transactionHash is ' + transactionHash);
    } else {
       console.log(error);
    }
});

在主链上转账以太币及代币

上面的方法只适用于私链。因为你在私链的账户在本地是有私钥的。而在主链上要进行写入数据的方法,是需要获取账户的私钥并对交易进行签名的,所以要用到web3.eth.sendSignedTransaction方法-文档

npm install ethereumjs-tx

以太币转账

// 引入ethereumjs-tx
var Tx = require('ethereumjs-tx');
 
// 以太币转账    
// 先获取当前账号交易的nonce
web3.eth.getTransactionCount(currentAccount, web3.eth.defaultBlock.pending).then(function(nonce){
 
    
    // 获取交易数据
    var txData = {
        // nonce每次++,以免覆盖之前pending中的交易
        nonce: web3.utils.toHex(nonce++),
        // 设置gasLimit和gasPrice
        gasLimit: web3.utils.toHex(99000),   
        gasPrice: web3.utils.toHex(10e9),  
        // 要转账的哪个账号  
        to: '0x3b11f5CAB8362807273e1680890A802c5F1B15a8',
        // 从哪个账号转
        from: currentAccount,
        // 0.001 以太币
        value: web3.utils.toHex(10e14),         
        data: ''
    }
 
    var tx = new Tx(txData);
 
    // 引入私钥,并转换为16进制
    const privateKey = new Buffer('your account privateKey', 'hex'); 
 
    // 用私钥签署交易
    tx.sign(privateKey);
 
    // 序列化
    var serializedTx = tx.serialize().toString('hex');
 
    web3.eth.sendSignedTransaction('0x' + serializedTx.toString('hex'), function(err, hash) {
        if (!err) {
            console.log(hash);
        } else {
            console.error(err);
        }
    });
});

代币转账

// 补齐64位,不够前面用0补齐
function addPreZero(num){
  var t = (num+'').length,
  s = '';
  for(var i=0; i<64-t; i++){
    s += '0';
  }
  return s+num;
}
 
web3.eth.getTransactionCount(currentAccount, web3.eth.defaultBlock.pending).then(function(nonce){
 
    // 获取交易数据
    var txData = {
        nonce: web3.utils.toHex(nonce++),
        gasLimit: web3.utils.toHex(99000),   
        gasPrice: web3.utils.toHex(10e9),
        // 注意这里是代币合约地址    
        to: contractAddress,
        from: currentAccount,
        // 调用合约转账value这里留空
        value: '0x00',         
        // data的组成,由:0x + 要调用的合约方法的function signature + 要传递的方法参数,每个参数都为64位(对transfer来说,第一个是接收人的地址去掉0x,第二个是代币数量的16进制表示,去掉前面0x,然后补齐为64位)
        data: '0x' + 'a9059cbb' + addPreZero('3b11f5CAB8362807273e1680890A802c5F1B15a8') + addPreZero(web3.utils.toHex(1000000000000000000).substr(2))
    }
 
    var tx = new Tx(txData);
 
    const privateKey = new Buffer('your account privateKey', 'hex'); 
 
    tx.sign(privateKey);
 
    var serializedTx = tx.serialize().toString('hex');
 
    web3.eth.sendSignedTransaction('0x' + serializedTx.toString('hex'), function(err, hash) {
        if (!err) {
            console.log(hash);
        } else {
            console.error(err);
        }
    });
});

到此这篇关于Web3.js查询以太币和代币余额以及转账的文章就介绍到这了,更多相关Web3.js 转账余额查询内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • javascript添加前置0(补零)的几种方法

    javascript添加前置0(补零)的几种方法

    很多时候为了显示格式,需要在某一字符串不满位的情况下进行前补0操作。下面这篇文章就给大家主要介绍了javascript添加前置0(补零)的几种方法,文中给出了详细的示例代码,需要的朋友可以参考借鉴,下面来一起看看吧。
    2017-01-01
  • 记录一篇关于redux-saga的基本使用过程

    记录一篇关于redux-saga的基本使用过程

    这篇文章主要介绍了记录一篇redux-saga的基本使用过程,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2018-08-08
  • javascript getElementsByTagName

    javascript getElementsByTagName

    DC大神为早期不支持getElementsByTagName的浏览器写的hack,当然与原生的不能同日而言,原生的用到缓存机制呢。
    2011-01-01
  • js中Number数字数值运算后值不对的解决方法

    js中Number数字数值运算后值不对的解决方法

    下面小编就为大家带来一篇js中Number数字数值运算后值不对的解决方法。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2017-02-02
  • 如何正确使用javascript 来进行我们的程序开发

    如何正确使用javascript 来进行我们的程序开发

    Javascript 正确使用方法,下面为大家介绍的是一个关于如何正确使用javascript 来进行我们的程序开发,需要的朋友可以参考下
    2014-06-06
  • 判断数组的最佳方法(推荐)

    判断数组的最佳方法(推荐)

    下面小编就为大家带来一篇js判断数组的最佳方法(推荐)。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2016-10-10
  • js播放wav文件(源码)

    js播放wav文件(源码)

    如何用JS播放wav文件,理论上用js在网页里嵌入一个window播放器的插件,可以播放的。,不过通用性不是很好,IE下可以用,感兴趣的朋友可以参考下哈本文
    2013-04-04
  • 如何利用js实时监听input输入框值的变化

    如何利用js实时监听input输入框值的变化

    在做web开发时候很多时候都需要即时监听输入框值的变化,以便作出即时动作去引导浏览者增强网站的用户体验感,这篇文章主要给大家介绍了关于如何利用js实时监听input输入框值的变化,需要的朋友可以参考下
    2024-02-02
  • JavaScript+CSS无限极分类效果完整实现方法

    JavaScript+CSS无限极分类效果完整实现方法

    这篇文章主要介绍了JavaScript+CSS无限极分类效果完整实现方法,涉及JavaScript针对页面元素节点遍历与动态操作技巧,需要的朋友可以参考下
    2015-12-12
  • JavaScript通过RegExp实现客户端验证处理程序

    JavaScript通过RegExp实现客户端验证处理程序

    通过RegExp实现客户端验:让文本框只允许输入数字、文本框只允许输入中文、邮箱输入格式的判断等等,具体实现如下,感兴趣的朋友可以参考下哈
    2013-05-05

最新评论