본문으로 건너뛰기

ethers.js를 사용하여 토큰 전송하기

ETHERS.JS
ERC-20
토큰
초급
김용준
2021년 4월 6일
4 분 소요

ethers.js(5.0)를 사용하여 토큰 전송하기

이 튜토리얼에서 배우게 될 내용

  • ethers.js 가져오기
  • 토큰 전송
  • 네트워크 트래픽 상황에 따른 가스 가격 설정

시작하기

시작하려면 먼저 JavaScript에 ethers.js 라이브러리를 가져와야 합니다. 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: 트랜잭션에 서명하고 실제로 토큰을 전송하기 위한 송신자의 개인 키

주의사항

sendTransaction()가 내부적으로 처리하므로 signTransaction(tx)는 제거되었습니다.

전송 절차

1. 네트워크(테스트넷) 연결

프로바이더 설정 (Infura)

롭스텐 테스트넷에 연결

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() // 가스 가격

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 finished!")
})

사용 방법

성공!

image of transaction done successfully

send_token()