• 建立本地区块链
• 部署智能合约
• 从控制台交互
• 以编程方式交互
• 获取合约实例
• 调用合约
• 发送交易
• OpenZeppelin Tutorials 教程
• Contact 联系方式

• 建立本地区块链

在开始之前,我们首先需要一个可以部署合约的环境。以太坊区块链(通常称为“主网”,表示“主网络”)需要花费真金白银才能使用它,以以太币(其本币)的形式。在尝试新想法或工具时,这使其成为一个糟糕的选择。

为了解决这个问题,存在许多“测试网络”(用于“测试网络”):其中包括 Ropsten、Rinkeby、Kovan 和 Goerli 区块链。它们的工作方式与主网非常相似,但有一个区别:您可以免费获得这些网络的以太币,因此使用它们不会花费您一分钱。但是,您仍然需要处理私钥管理、5 到 20 秒范围内的阻塞时间,以及实际获得这个免费的 Ether。

在开发过程中,最好使用本地区块链。它在您的机器上运行,不需要互联网访问,为您提供所需的所有以太币,并立即挖掘区块。这些原因也使得本地区块链非常适合自动化测试。

Hardhat 带有一个内置的本地区块链,即Hardhat Network。

启动时,Hardhat Network 将创建一组未锁定的帐户并为它们提供以太币。

$ npx hardhat node

Hardhat Network 将打印出其地址,http://127.0.0.1:8545以及可用帐户及其私钥的列表。

请记住,每次运行 Hardhat Network 时,它都会创建一个全新的本地区块链 -不会保留之前运行的状态。这对于短期实验来说很好,但这意味着您需要在这些指南期间打开一个运行 Hardhat Network 的窗口。

• 部署智能合约

在开发智能合约指南中,我们设置了我们的开发环境。

如果您还没有此设置,请创建并设置项目,然后创建并编译我们的 Box 智能合约。

随着我们的项目设置完成,我们现在可以部署合约了。我们将从Box开发智能合约指南中进行部署。确保您有Box in的副本contracts/Box.sol。

Hardhat 目前没有原生部署系统,而是使用脚本来部署合约。

我们将创建一个脚本来部署我们的 Box 合约。我们将此文件另存为scripts/deploy.js.

// scripts/deploy.jsasync function main () {// We get the contract to deployconst Box = await ethers.getContractFactory('Box');console.log('Deploying Box...');const box = await Box.deploy();await box.deployed();console.log('Box deployed to:', box.address);}main().then(() => process.exit(0)).catch(error => {console.error(error);process.exit(1);});

我们在脚本中使用了ethers,因此我们需要安装它和@nomiclabs/hardhat-ethers 插件。

$ npm install --save-dev @nomiclabs/hardhat-ethers ethers

我们需要添加我们正在使用插件的配置。@nomiclabs/hardhat-ethers

// hardhat.config.jsrequire('@nomiclabs/hardhat-ethers');...module.exports = {...};

全部完成!在真实的网络上,这个过程需要几秒钟,但在本地区块链上几乎是即时的。

• 从控制台交互

部署Box合约后,我们可以立即开始使用它。

我们将使用Hardhat 控制台与我们Box在 localhost 网络上部署的合约进行交互。

npx hardhat console --network localhostWelcome to Node.js v12.22.1.Type ".help" for more information.> const Box = await ethers.getContractFactory('Box');undefined> const box = await Box.attach('0x5FbDB2315678afecb367f032d93F642f64180aa3')undefined

发送交易
Box的第一个函数store接收一个整数值并将其存储在合约存储中。因为这个函数修改了区块链状态,所以我们需要向合约发送一个交易来执行它。

我们将发送一个事务来调用store具有数值的函数:

> await box.store(42){hash: '0x3d86c5c2c8a9f31bedb5859efa22d2d39a5ea049255628727207bc2856cce0d3',

查询状态
Box的另一个函数被调用retrieve,它返回存储在合约中的整数值。这是区块链状态的查询,所以我们不需要发送交易:

> await box.retrieve()BigNumber { _hex: '0x2a', _isBigNumber: true }

• 以编程方式交互

控制台对于原型设计和运行一次性查询或事务很有用。但是,最终您将希望通过自己的代码与您的合约进行交互。

在本节中,我们将了解如何通过 JavaScript 与我们的合约进行交互,并使用Hardhat通过我们的 Hardhat 配置运行我们的脚本。

设置
让我们开始在一个新scripts/index.js文件中编码,我们将在其中编写 JavaScript 代码,从一些样板开始,包括编写异步代码。

// scripts/index.jsasync function main () {// Our code will go here}main().then(() => process.exit(0)).catch(error => {console.error(error);process.exit(1);});

我们可以通过询问本地节点来测试我们的设置,例如启用的帐户列表:

// Retrieve accounts from the local nodeconst accounts = await ethers.provider.listAccounts();console.log(accounts);

使用 运行上面的代码hardhat run,并检查您是否获得了可用帐户列表作为响应。

$ npx hardhat run --network localhost ./scripts/index.js['0xf39Fd6e51aad88F6F4ce6aB8827279cffFb92266','0x70997970C51812dc3A010C7d01b50e0d17dc79C8',...]

这些帐户应与您之前启动本地区块链时显示的帐户相匹配。现在我们有了第一个从区块链中获取数据的代码片段,让我们开始使用我们的合约。请记住,我们在上面定义的main函数中添加了代码。

• 获取合约实例

为了与Box我们部署的合约进行交互,我们将使用一个以太合约实例。

ethers 合约实例是一个 JavaScript 对象,它代表我们在区块链上的合约,我们可以使用它与我们的合约进行交互。要将其附加到我们部署的合约中,我们需要提供合约地址。

// Set up an ethers contract, representing our deployed Box instanceconst address = '0x5FbDB2315678afecb367f032d93F642f64180aa3';const Box = await ethers.getContractFactory('Box');const box = await Box.attach(address);

• 调用合约

让我们从显示Box合约的当前价值开始。

我们需要调用合约的只读retrieve()公共方法,并等待响应:

// Call the retrieve() function of the deployed Box contractconst value = await box.retrieve();console.log('Box value is', value.toString());

这个片段相当于我们之前从控制台运行的查询。现在,通过再次运行脚本并检查打印值来确保一切运行顺利:

npx hardhat run --network localhost ./scripts/index.jsBox value is 42

• 发送交易

现在,我们将向storeBox 中的新值发送交易。

让我们在 中存储一个值,然后使用23我们Box之前编写的代码来显示更新后的值:

// Send a transaction to store() a new value in the Boxawait box.store(23);// Call the retrieve() function of the deployed Box contractconst value = await box.retrieve();console.log('Box value is', value.toString());

我们现在可以运行代码片段,并检查框的值是否已更新!

$ npx hardhat run --network localhost ./scripts/index.jsBox value is 23

• OpenZeppelin Tutorials 教程

CN 中文 Github OpenZeppelin 教程 : github.com/565ee/OpenZeppelin_CN
CN 中文 CSDN OpenZeppelin 教程 : blog.csdn.net/wx468116118
EN 英文 Github OpenZeppelin Tutorials : github.com/565ee/OpenZeppelin_EN

• Contact 联系方式

Homepage : 565.ee
微信公众号 : wx468116118
微信 QQ : 468116118
GitHub : github.com/565ee
CSDN : blog.csdn.net/wx468116118
Email : 468116118@qq.com