Web3.js查詢以太幣和代幣余額及轉(zhuǎn)賬
安裝
npm install web3
web3.js查詢以太幣及代幣余額以及進(jìn)行以太幣和代幣轉(zhuǎn)賬
在私鏈和主鏈上查詢以太幣及代幣余額
查詢類方法在私鏈和主鏈上的方法都是一樣的
主鏈地址??梢匀?code>infura申請(qǐng)
contractAbi。合約的abi??梢匀?a rel="external nofollow" target="_blank">https://etherscan.io獲取,如果代幣合約提供了code,就會(huì)有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";
// 賬號(hào)
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);
// 查看某個(gè)賬號(hào)的代幣余額
myContract.methods.balanceOf(contractAddress).call({from: currentAccount}, function(error, result){
if(!error) {
console.log(result);
} else {
console.log(error);
}
});這里還可以查詢代幣的名稱,符號(hào),小數(shù)位,發(fā)行總量等等,因?yàn)榇鷰藕霞s一般都符合
ERC標(biāo)準(zhǔn),都有這些基本方法。甚至如果你有合約代碼和abi,還可以調(diào)用合約的其他方法,當(dāng)然調(diào)用有些方法需要權(quán)限及前置條件
// 獲得代幣名稱
myContract.methods.name().call({from: currentAccount}, function(error, result){
if(!error) {
console.log(result);
} else {
console.log(error);
}
});
// 獲取代幣符號(hào)
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);
}
});
// 查看某個(gè)賬號(hào)允許另一個(gè)賬號(hào)可使用的代幣數(shù)量
myContract.methods.allowance(sender, spender).call({from: currentAccount}, function(error, result){
if(!error) {
console.log(result);
} else {
console.log(error);
}
});在私鏈上轉(zhuǎn)賬以太幣及代幣
// 以太幣轉(zhuǎn)賬
web3.eth.sendTransaction({
from: currentAccount,
to: receiverAccount,
value: '1000000000000000'
})
.then(function(receipt){
console.log(receipt);
});
// 代幣轉(zhuǎn)賬
myContract.methods.transfer(to, amount).send({from: currentAccount}), function(error, transactionHash){
if(!error) {
console.log('transactionHash is ' + transactionHash);
} else {
console.log(error);
}
});在主鏈上轉(zhuǎn)賬以太幣及代幣
上面的方法只適用于私鏈。因?yàn)槟阍谒芥湹馁~戶在本地是有私鑰的。而在主鏈上要進(jìn)行寫(xiě)入數(shù)據(jù)的方法,是需要獲取賬戶的私鑰并對(duì)交易進(jìn)行簽名的,所以要用到
web3.eth.sendSignedTransaction方法-文檔
npm install ethereumjs-tx
以太幣轉(zhuǎn)賬
// 引入ethereumjs-tx
var Tx = require('ethereumjs-tx');
// 以太幣轉(zhuǎn)賬
// 先獲取當(dāng)前賬號(hào)交易的nonce
web3.eth.getTransactionCount(currentAccount, web3.eth.defaultBlock.pending).then(function(nonce){
// 獲取交易數(shù)據(jù)
var txData = {
// nonce每次++,以免覆蓋之前pending中的交易
nonce: web3.utils.toHex(nonce++),
// 設(shè)置gasLimit和gasPrice
gasLimit: web3.utils.toHex(99000),
gasPrice: web3.utils.toHex(10e9),
// 要轉(zhuǎn)賬的哪個(gè)賬號(hào)
to: '0x3b11f5CAB8362807273e1680890A802c5F1B15a8',
// 從哪個(gè)賬號(hào)轉(zhuǎn)
from: currentAccount,
// 0.001 以太幣
value: web3.utils.toHex(10e14),
data: ''
}
var tx = new Tx(txData);
// 引入私鑰,并轉(zhuǎn)換為16進(jìn)制
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);
}
});
});代幣轉(zhuǎn)賬
// 補(bǔ)齊64位,不夠前面用0補(bǔ)齊
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){
// 獲取交易數(shù)據(jù)
var txData = {
nonce: web3.utils.toHex(nonce++),
gasLimit: web3.utils.toHex(99000),
gasPrice: web3.utils.toHex(10e9),
// 注意這里是代幣合約地址
to: contractAddress,
from: currentAccount,
// 調(diào)用合約轉(zhuǎn)賬value這里留空
value: '0x00',
// data的組成,由:0x + 要調(diào)用的合約方法的function signature + 要傳遞的方法參數(shù),每個(gè)參數(shù)都為64位(對(duì)transfer來(lái)說(shuō),第一個(gè)是接收人的地址去掉0x,第二個(gè)是代幣數(shù)量的16進(jìn)制表示,去掉前面0x,然后補(bǔ)齊為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);
}
});
});到此這篇關(guān)于Web3.js查詢以太幣和代幣余額以及轉(zhuǎn)賬的文章就介紹到這了,更多相關(guān)Web3.js 轉(zhuǎn)賬余額查詢內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
記錄一篇關(guān)于redux-saga的基本使用過(guò)程
這篇文章主要介紹了記錄一篇redux-saga的基本使用過(guò)程,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2018-08-08
javascript getElementsByTagName
DC大神為早期不支持getElementsByTagName的瀏覽器寫(xiě)的hack,當(dāng)然與原生的不能同日而言,原生的用到緩存機(jī)制呢。2011-01-01
js中Number數(shù)字?jǐn)?shù)值運(yùn)算后值不對(duì)的解決方法
下面小編就為大家?guī)?lái)一篇js中Number數(shù)字?jǐn)?shù)值運(yùn)算后值不對(duì)的解決方法。小編覺(jué)得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2017-02-02
如何正確使用javascript 來(lái)進(jìn)行我們的程序開(kāi)發(fā)
Javascript 正確使用方法,下面為大家介紹的是一個(gè)關(guān)于如何正確使用javascript 來(lái)進(jìn)行我們的程序開(kāi)發(fā),需要的朋友可以參考下2014-06-06
如何利用js實(shí)時(shí)監(jiān)聽(tīng)input輸入框值的變化
在做web開(kāi)發(fā)時(shí)候很多時(shí)候都需要即時(shí)監(jiān)聽(tīng)輸入框值的變化,以便作出即時(shí)動(dòng)作去引導(dǎo)瀏覽者增強(qiáng)網(wǎng)站的用戶體驗(yàn)感,這篇文章主要給大家介紹了關(guān)于如何利用js實(shí)時(shí)監(jiān)聽(tīng)input輸入框值的變化,需要的朋友可以參考下2024-02-02
JavaScript+CSS無(wú)限極分類效果完整實(shí)現(xiàn)方法
這篇文章主要介紹了JavaScript+CSS無(wú)限極分類效果完整實(shí)現(xiàn)方法,涉及JavaScript針對(duì)頁(yè)面元素節(jié)點(diǎn)遍歷與動(dòng)態(tài)操作技巧,需要的朋友可以參考下2015-12-12
JavaScript通過(guò)RegExp實(shí)現(xiàn)客戶端驗(yàn)證處理程序
通過(guò)RegExp實(shí)現(xiàn)客戶端驗(yàn):讓文本框只允許輸入數(shù)字、文本框只允許輸入中文、郵箱輸入格式的判斷等等,具體實(shí)現(xiàn)如下,感興趣的朋友可以參考下哈2013-05-05

