I've been revisiting ethers.js
recently to refresh my understanding of the details and to write a simple tutorial called "WTF Ethers" for beginners.
Twitter: @0xAA_Science
Community: Website wtf.academy | WTF Solidity | discord | WeChat Group Application
All the code and tutorials are open-sourced on GitHub: github.com/WTFAcademy/WTF-Ethers
In this lesson, we will introduce the Provider
class in ethers.js and use it to connect to a node to retrieve information from the blockchain.
Provider
Class
The Provider
class provides an abstraction for connecting to the Ethereum network and offers a concise and consistent interface for standard Ethereum node functionality. In ethers
, the Provider
class does not handle user private keys and can only read information from the blockchain, making it safer compared to web3.js
.
The most commonly used provider in ethers
is jsonRpcProvider
, which allows users to connect to a specific node service provider.
jsonRpcProvider
Creating an API Key for the Node Service Provider
First, you need to register and create an API Key on the website of the node service provider (e.g INFURA, ALCHEMY). In the "Tools" section of the "WTF Solidity" tutorial, we introduced the methods to create API Keys for two projects, Infura and Alchemy. You can refer to the tutorial for more information.
data:image/s3,"s3://crabby-images/6f478/6f478fd73c40d72566c5648f5e49ee0d2b98a36a" alt="Infura API Key"
Connecting to Infura Node
Here, we will use Infura as an example. After creating the Infura API Key, you can create a Provider
variable using the ethers.JsonRpcProvider()
method, which takes the URL of the node service as a parameter.
In the following example, we create providers to connect to the ETH
mainnet and the Sepolia
testnet:
Using the Provider
to Retrieve Blockchain Data
The Provider
class provides convenient methods to retrieve data from the blockchain:
1. Use the getBalance()
function to retrieve the ETH
balance of Vitalik on the mainnet and the Sepolia testnet:
data:image/s3,"s3://crabby-images/75b53/75b53f2115096f3d80ef7623e1da2511fe28a9e2" alt="Vitalik Balance"
2. Use the getNetwork()
function to check which chain the provider is connected to.
data:image/s3,"s3://crabby-images/5a62d/5a62dd899d5674b3614584da7edaa07e6f88a36a" alt="getNetwork"
3. Use the getBlockNumber()
function to retrieve the current block number:
data:image/s3,"s3://crabby-images/4407c/4407c83597d89c53e8702328a645e9372196e7bf" alt="getBlockNumber"
4. Use the getTransactionCount()
function to retrieve the transaction count of a wallet address.
data:image/s3,"s3://crabby-images/92159/921597cb9faad90455733e96be6217ecda761c29" alt=""
5. Use the getFeeData()
function to retrieve the current recommended gas settings, which are returned as bigint
.
data:image/s3,"s3://crabby-images/3b241/3b241a8417e89b6d6163e82e909ca6d2347063c1" alt="getFeeData"
6. Use the getBlock()
function to retrieve information about a specific block. The parameter is the block number:
data:image/s3,"s3://crabby-images/49c4d/49c4d5e45f76d59ed75e6e2acc2b23c9617d3cdf" alt="getBlock"
7. Use the getCode()
function to retrieve the bytecode of a contract at a specific address. In the example below, we use the contract address of WETH
on the mainnet:
data:image/s3,"s3://crabby-images/32ee4/32ee44a2c7793b8fa26d414eadf4ee0d5a2a5d14" alt="getCode"
Summary
In this lesson, we introduced the Provider
class of ethers.js and created a jsonRpcProvider
with Infura's node API key to read on-chain information from the ETH
main network and Sepolia
test network.