メインコンテンツへスキップ

ethers.jsを使用してトークンを送信する

ETHERS.JS
ERC-20
トークン
初級
Kim YongJun
2021年4月6日
4 分の読書

ethers.js(5.0)を使用したトークンの送信

このチュートリアルで学ぶこと

  • ethers.jsのインポート
  • トークンの転送
  • ネットワークの混雑状況に応じたガス代の設定

はじめに

始めるには、まずethers.jsライブラリをJavaScriptにインポートする必要があります。 ethers.js(5.0)をインクルードします。

インストール

/home/ricmoo> npm install --save ethers

ブラウザでES6を使用するには次のようにします。

<script type="module">
  import { ethers } from "https://cdn.ethers.io/lib/ethers-5.0.esm.min.js"
  // ここにコードを記述...
</script>

ブラウザでES3(UMD)を使用するには次のようにします。

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

パラメータ

  1. contract_address: トークンのコントラクトアドレス(転送したいトークンがイーサでない場合は、コントラクトアドレスが必要となります)
  2. send_token_amount: 受取人に送る量
  3. to_address: 受取人のアドレス
  4. send_account: 送信者のアドレス
  5. private_key: トランザクションに署名し、実際にトークンを転送するための送信者の秘密鍵

注意

signTransaction(tx)は、sendTransaction()の内部で実行されるため削除されました。

送信手順

1. ネットワークに接続 (テストネット)

プロバイダーの設定 (Infura)

Ropstenテストネットに接続します。

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

2. ウォレットの作成

let wallet = new ethers.Wallet(private_key)

3. ウォレットをネットワークに接続

let walletSigner = wallet.connect(window.ethersProvider)

4. 現在のガス価格の取得

window.ethersProvider.getGasPrice() // gasPrice

5. トランザクションの定義

以下で定義されている変数は、send_token()に依存します。

トランザクションパラメータ

  1. send_account: トークン送信者のアドレス
  2. to_address: トークンの受取人のアドレス
  3. send_token_amount: 送信するトークンの量
  4. gas_limit: ガスリミット
  5. gas_price: ガス価格

使用方法については、以下を参照してください

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

6. 転送

walletSigner.sendTransaction(tx).then((transaction) => {
  console.dir(transaction)
  alert("送信完了!")
})

使用方法

成功しました!

トランザクションが正常に完了した画像

send_token()

ページの最終更新: 2026年3月3日

このチュートリアルは役に立ちましたか?