以太坊标准JS API库——浅谈Web3.js与Ethers.js

阿里云国内75折 回扣 微信号:monov8
阿里云国际,腾讯云国际,低至75折。AWS 93折 免费开户实名账号 代冲值 优惠多多 微信号:monov8 飞机:@monov6

web3.js与ethers.js/hardhat-ethers介绍

版本号
Web3.js v1.7.3
Ethers.js v.5.6

简单介绍web3.js

web3.js是一个标准的以太坊JavaScript API库该JS库由以太坊基金会开发维护同时它也是最早且使用最广泛的一个ETH API库。由于Moonbeam完全兼容以太坊EVM因此web3.js可以在Moonbeam上进行正常交互

web3.js(v1.7.3)库官方使用文档https://web3js.readthedocs.io/en/v1.7.3/index.html

web3.js的安装与常用API介绍

安装web3.js

在命令终端输入npm install web3即可正常安装

常用API介绍

1. 签名交易web3.eth.accounts.signTransaction()

web3.eth.accounts.signTransaction(tx, privateKey, [, callback]) => promise<object>

第一个参数为tx即定义该交易的细则在其中可以定义的交易细则有gastovaluegasPrice等参数其中gas是必须要设置的参数其余用到的交易参数都是可选择的gas参数规定了该交易将要花费的gas费用to参数则说明了这笔交易的接受者而value参数则规定了这笔交易中转移代币的数量
第二个参数为privateKey为发起交易人的私钥该交易将由该私钥进行签署

第三个参数为callback该参数为一个可选参数该回调函数返回的第一个参数为一个错误对象第二个参数为结果对象

该接口返回一个Promise对象如果签署交易成功将会返回该交易的一些具体信息如messageHashrawTransactiontransactionHash等信息

2. 部署合约contractInstance.deploy()

new web3.eth.Contract(jsonInterface[, address][, options]) => promise<contract>

该方法用于生产合约实例只有通过合约实例才能进行部署操作。该函数只需要填写一个一个参数即可jsonInterface即为该合约的abi填入该参数即可完成合约实例的生成

contractInstace.deploy(options) => promise<transaction>

改方法用于部署合约调用该函数将返回部署合约交易的具体信息
其中的参数为options其中里面可以写入两个部分即data(String)与arguments(Array)两个参数data参数为合约的bytecodearguments参数为合约构造函数中的参数因此该参数为可选的

deploy函数会返回一个交易对象该对象自带一个数组与4个函数数组表示先前传入的构造函数的入参四个函数分别为send()estimateGas()encodeABI()createAccessList()

3. 调用合约方法methods.myMethod.call()

myContract.methods.myMethod(param1[, param2[, ...]]).call(options [, defaultBlock] [, callback]) => returnValuesOfContract

该方法用于调用一个“constant”方法并在不发起任何交易的同时在EVM执行智能合约的方法使用此方法调用的智能合约方法均不会改变合约状态
其中myMethod()括号中填入的参数为该方法的入参call()中填入的options包含如下几个方面的值from、gasPrice、gascall()中还可以选择性的填入defaultBlock与callback其中defaultBlock为默认区块设置callback回调函数第一个参数为错误对象第二个参数为合约方法结果

该方法会返回调用函数的返回结果如果返回结果为多个则返回一个带有索引的对象

4. 订阅监听事件web3.eth.subscribe()

web3.eth.subscribe(type [, options] [, callback]) => subscriptionInstance

该方法用于订阅监听智能合约中触发的事件
其中订阅方法包含四种方法分别为pendingTransactionsnewBlockHeaderssyncinglogs

监听事件一般采用newBlockHeaders模式该模式订阅监听传入的区块头该特性可以作为计时器来检查区块链上的变化。callback参数与上述函数一样第一个参数为错误对象第二个参数为结果对象

同时在该函数的返回内容中有几个回调函数比较常见on("connected"), on("data"), on("error"), on("changed")

  1. 一旦订阅成功连接则触发on("connected")该函数返回订阅id;
  2. 当log有数据时触发on("data")
  3. 当订阅出错时触发on("error")
  4. 当有log被删除出区块链时触发on("changed")

简单介绍Ethers.js

Ethers.js与Web3.js一样都是以太坊标准JavaScript API库Ethers.js最初是为了ethers.io设计后来拓展为一个开放的JS API库与Web3.js相同的是Ethers.js同样可以与Moonbeam进行正常交互这得益于Moonbeam是一个完全兼容以太坊EVM的智能合约平台而与Web3.js不同的是Ethers.js在使用时不需要过多的回调函数而且可以搭配Hardhat工具是的语法得到进一步的优化

Ethers.js(Hardhat)的安装与常用API介绍

Ethers.js(Hardhat)的安装

Ethers.js的安装分为两种一种为直接使用命令行安装另一种为通过Hardhat间接安装配合Hardhat使用推荐第二种通过Hardhat👷的方式使用Ethers.js安装Hardhat时通过hardhat-ethers插件安装经过包装后的Ethers.js

安装步骤如下

// command line
npm install --save ethers

// install Hardhat
npm init
npm install --save-dev hardhat
npx hardhat

常用API介绍

Ethers.js库中的API主要由4大部分组成ProvidersSignersContract InteractionUtilities

1. Provider

Provider是以太坊网络连接的抽象其为标准以太坊节点功能提供简洁、一致的接口

在Provider中比较常用的方法为JsonRpcProvider该方法允许通过JSON-RPC的方式连接某一个节点网络

// new ethers.providers.JsonRpcProvider([urlOrConnectionInfo[, networkish]])
const provider = new ethers.providers.JsonRpcProvider(
        'https://rpc.api.moonbase.moonbeam.network',
        {
            chainId: 1287,
            name: 'moonbase-alpha'
        }
);

在上面的代码示例中通过JsonRpcProvider的方式连接到了Moonbase Alpha测试网中在其中不止可以定义url参数还可以定义该网络的chainId与name等信息

2. Signers

Signer是以太坊账户的抽象可用于对消息和交易进行签名并将签名过的交易发送到以太坊网络以执行状态更改操作

在Signer中比较常用的方法为Wallet只有Wallet可以使用私钥对交易和信息进行签名

// new ethers.Wallet(privateKey[, provider])
const alice = new ethers.Wallet(privateKeyAlice, provider);
const bob = new ethers.Wallet(privateKeyBob, provider);

const txReceipt = await alice.sendTransaction({
    to: bob.address,
    value: ethers.utils.parseEther('1.0')
});
await txReceipt.wait();

在上面的代码示例中使用Wallet定义了alice与bob两个Signer接下来alice调用方法sendTransaction()方法向bob发起交易转移了1 ether的token

3. Contract Interaction

部署合约与生成合约实例离不开下面介绍的两个方法ContractFactory()与Contract具体方法直接看下面的代码示例接口

// deploy contract
new ethers.ContractFactory(interface, bytecode[, signer])
contractFactory.deploy(..args)
contract.deployed()

// generate contract instance
new ethers.Contract(address, abi, signerOrProvider)

其中ContracFactory中的interface参数代表合约的abi
使用Hardhat编译过后的合约其abi与bytecode等编译信息都存放在了项目根目录下的artifacts/contracts/CONTRACT_NAME.json文件中

4. Utilities

utilities下提供的各种方法更像是各种各样的工具比较常用的有对BigNumber的操作以太坊Token单位的直接转换以及将string于bytes32相互转化的工具等以下列出几个常见方法

// BigNumber
BigNumber.toNumber() => number
BigNumber.toHexString() => string<DataHexString>

// Display Logic and Input
ethers.utils.parseEther(string) => BigNumber
ethers.utils.formatEther(value(BigNumber)) => string

// Strings
ethers.utils.parseBytes32String(aBytesLike) => string
ethers.utils.formatBytes32String(text) => string<DataHexString<32>>
  1. BigNumber.toNumber()将BigNumber的值转换为JavaScript值

  2. BigNumber.toHexString()将BigNumber值转换为0x开头16进制的值

  3. ethers.utils.parseEther(string)将一个整数转换为以ether为单位的大整数

  4. ethers.utils.formatEther(value(BigNumber))将大整数转换为以ether为单位的整数

  5. ethers.utils.parseBytes32String(aBytesLike)返回一个bytes 32编码数据表示的解码字符串

  6. ethers.utils.formatBytes32String(text)返回文本的bytes 32字符串表示形式

hardhat-ethers升级接口

使用原生Ethers.js库进行与节点进行交互时特别在部署合约方面的接口使用中会发现原生接口的调用比较麻烦

因此Hardhat在此方面做了优化即Hardhat提供了一个hardhat-ethers插件该插件会提供一个ethers对象该对象与Ethers.js有着相同的API同时还有一些Hardhat特别定义的接口

其特别定义的接口主要体现在以下是三个方面

  • 不需要额外定义providerprovider已经在执行npx hardhat --network NET run SCRIPT 命令时已自动连接到了选定网络中
  • getSigner() => Signer该接口直接在hardhat配置中获取signer不需要定义wallet但需要提前将账户私钥信息填写到Hardhat配置文件中
  • getContracFactory(contractName[, signer]) => contractFactory该接口简化了原生contractFactory()接口使得只需要合约的名字即可产生contractFactory对象
    以部署一个ERC-20合约为例
// using hardhat-ethers API to deploy an ERC20 contract

// get signer
const alith = await ethers.getSigner(1);
// deploy contract
const Token = await ehters.getContractFactory('Token', alith);
const token = await Token.deploy('MoonToken', 'MTK', 100);
await token.deployed();

// using raw ethers.js API to deploy the same ERC20 contract

// get provider and signer
const provider = new ethers.providers.JsonRpcProvider('http://localhost:9933');
const alith = new ethers.Wallet(privateKeyAlith, provider);
// deploy contract
const Token = new ethers.ContractFactory(interface, bytecode, alith);
const token = await Token.deploy('MoonToken', 'MTK', 100);
await token.deployed();

通过上面的代码示例可以很直观的发现使用hardhat-ethers提供的API在部署合约时会更方便一些


Web3.js与Ethers.js都属于以太坊标准JavaScript API库二者各有特点同样被广大的Web3开发者接受

Web3.js属于比较老牌的API库功能比较强大但是使用过程中需要注意各种回调函数而Ethers.js属于新兴起的API库其最大的特点在于其接口调用简单方便对于不是很熟悉JS的开发者来说比较友好。

阿里云国内75折 回扣 微信号:monov8
阿里云国际,腾讯云国际,低至75折。AWS 93折 免费开户实名账号 代冲值 优惠多多 微信号:monov8 飞机:@monov6
标签: 区块链