Web3通过ganache运行起一个本地虚拟区块链

通过文章 Web3开发准备工作 手把手带你创建自己的 MetaMask 账号大家简单的对网络 有了个比较模糊的概念
不同的网络连接这不同的区块链 那么 我们就要搞清楚 我们切换不同的网络 我们的数字资产是不一样的

在这里 我们需要先安装一个插件工具 ganache
我们先在本地创建一个文件夹
在这里插入图片描述
然后在这个文件夹下打开项目终端
在这里插入图片描述
在终端输入

npm i ganache -g

等它安装完毕 我们的依赖就进来了
在这里插入图片描述
要验证的话 方法比较麻烦 你需要通过管理员身份运行这个目录的终端
在这里插入图片描述
然后在终端 输入 ganache 回车
这里就会输出相关信息
在这里插入图片描述

这样 他就在 本地 给我们启动了一个模拟区块链

而且这里 它给我们创建了十个账号
在这里插入图片描述
上面对应的信息 就是我们账号的公钥 然后 后面是 对应的以太坊币数量 都是 一千以太坊币 就可以操作了

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
首先,你需要安装 Node.js,可以在官网下载对应的版本:https://nodejs.org/en/download/ 接着,可以使用 npm(Node.js 的包管理工具)安装 GanacheWeb3.js: ``` npm install -g ganache-cli web3 ``` 安装完成后,可以在命令行中执行以下命令启动 Ganache: ``` ganache-cli ``` 这会在本地启动一个以太坊仿真节点,你可以在浏览器中访问 http://localhost:8545 来查看节点信息。 接下来,可以使用 Web3.js 连接到 Ganache 节点,并在其中部署和测试 Solidity 智能合约。例如,可以使用以下代码连接到 Ganache 节点: ``` const Web3 = require('web3'); const web3 = new Web3('http://localhost:8545'); ``` 然后,可以使用 web3.js 提供的接口编写 Solidity 智能合约,并使用以下代码将其部署到 Ganache 节点上: ``` const fs = require('fs'); const solc = require('solc'); const contractSource = fs.readFileSync('MyContract.sol', 'utf8'); const compiledContract = solc.compile(contractSource, 1); const contractABI = JSON.parse(compiledContract.contracts[':MyContract'].interface); const contractBytecode = compiledContract.contracts[':MyContract'].bytecode; const MyContract = new web3.eth.Contract(contractABI); MyContract.deploy({ data: contractBytecode, arguments: [123, 'hello'] }).send({ from: '0x123...', gas: 1500000, gasPrice: '30000000000000' }).then((newContractInstance) => { console.log(newContractInstance.options.address); }); ``` 这会将编写的 MyContract 合约部署到 Ganache 节点上,并输出新合约实例的地址。 最后,可以使用 Web3.js 提供的接口与部署的合约进行交互,例如: ``` MyContract.methods.myFunction().call().then((result) => { console.log(result); }); ``` 这会调用 MyContract 合约中的 myFunction 函数,并输出返回结果。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值