跳转至主要内容

使用 ethers.js 发送代币

ETHERS.JS
ERC-20
代币
初学者
Kim YongJun
2021年4月6日
3 分钟阅读

使用 ethers.js (5.0) 发送代币

在本教程中,你将学习如何:{#you-learn-about}

  • 导入 ethers.js
  • 转账代币
  • 根据网络流量情况设置燃料价格

开始上手

开始前,我们必须先将 ethers.js 程序库导入到我们的 javascript 中 包含 ethers.js (5.0)

安装

1/home/ricmoo> npm install --save ethers

浏览器中的 ES6

1<script type="module">
2 import { ethers } from "https://cdn.ethers.io/lib/ethers-5.0.esm.min.js"
3 // 在此编写你的代码…
4</script>

浏览器中的 ES3 (UMD)

1<script
2 src="https://cdn.ethers.io/lib/ethers-5.0.umd.min.js"
3 type="application/javascript"
4></script>

参数

  1. contract_address:代币合约地址(如果你想转账的代币不是以太币,则需要合约地址)
  2. send_token_amount:你想要发送给接收方的金额
  3. to_address:接收方的地址
  4. send_account:发送方的地址
  5. private_key:发送方的私钥,用于签署交易并实际转账代币

注意

signTransaction(tx) 已被移除,因为 sendTransaction() 会在内部执行它。

发送流程

1. 连接到网络 (测试网)

设置提供者 (Infura)

连接到 Ropsten 测试网

1window.ethersProvider = new ethers.providers.InfuraProvider("ropsten")

2. 创建钱包

1let wallet = new ethers.Wallet(private_key)

3. 将钱包连接到网络

1let walletSigner = wallet.connect(window.ethersProvider)

4. 获取当前燃料价格

1window.ethersProvider.getGasPrice() // gasPrice

5. 定义交易

下面定义的变量取决于 send_token()

交易参数

  1. send_account:代币发送方的地址
  2. to_address:代币接收方的地址
  3. send_token_amount:要发送的代币数量
  4. gas_limit:燃料限制
  5. gas_price:燃料价格

请参阅下文了解如何使用

1const tx = {
2 from: send_account,
3 to: to_address,
4 value: ethers.utils.parseEther(send_token_amount),
5 nonce: window.ethersProvider.getTransactionCount(send_account, "latest"),
6 gasLimit: ethers.utils.hexlify(gas_limit), // 100000
7 gasPrice: gas_price,
8}

6. 转账

1walletSigner.sendTransaction(tx).then((transaction) => {
2 console.dir(transaction)
3 alert("发送完成!")
4})

如何使用

1let private_key =
2 "41559d28e936dc92104ff30691519693fc753ffbee6251a611b9aa1878f12a4d"
3let send_token_amount = "1"
4let to_address = "0x4c10D2734Fb76D3236E522509181CC3Ba8DE0e80"
5let send_address = "0xda27a282B5B6c5229699891CfA6b900A716539E6"
6let gas_limit = "0x100000"
7let wallet = new ethers.Wallet(private_key)
8let walletSigner = wallet.connect(window.ethersProvider)
9let contract_address = ""
10window.ethersProvider = new ethers.providers.InfuraProvider("ropsten")
11
12send_token(
13 contract_address,
14 send_token_amount,
15 to_address,
16 send_address,
17 private_key
18)
显示全部

成功!

交易成功完成的图片

send_token()

1function send_token(
2 contract_address,
3 send_token_amount,
4 to_address,
5 send_account,
6 private_key
7) {
8 let wallet = new ethers.Wallet(private_key)
9 let walletSigner = wallet.connect(window.ethersProvider)
10
11 window.ethersProvider.getGasPrice().then((currentGasPrice) => {
12 let gas_price = ethers.utils.hexlify(parseInt(currentGasPrice))
13 console.log(`gas_price: ${gas_price}`)
14
15 if (contract_address) {
16 // 常规代币发送
17 let contract = new ethers.Contract(
18 contract_address,
19 send_abi,
20 walletSigner
21 )
22
23 // 多少代币?
24 let numberOfTokens = ethers.utils.parseUnits(send_token_amount, 18)
25 console.log(`numberOfTokens: ${numberOfTokens}`)
26
27 // 发送代币
28 contract.transfer(to_address, numberOfTokens).then((transferResult) => {
29 console.dir(transferResult)
30 alert("已发送代币")
31 })
32 } // 以太币发送
33 else {
34 const tx = {
35 from: send_account,
36 to: to_address,
37 value: ethers.utils.parseEther(send_token_amount),
38 nonce: window.ethersProvider.getTransactionCount(
39 send_account,
40 "latest"
41 ),
42 gasLimit: ethers.utils.hexlify(gas_limit), // 100000
43 gasPrice: gas_price,
44 }
45 console.dir(tx)
46 try {
47 walletSigner.sendTransaction(tx).then((transaction) => {
48 console.dir(transaction)
49 alert("发送完成!")
50 })
51 } catch (error) {
52 alert("发送失败!!")
53 }
54 }
55 })
56}
显示全部

页面最后更新: 2023年12月4日

本教程对你有帮助吗?