当前位置: 首页 > wzjs >正文

自己做电影网站违法微信视频号小店

自己做电影网站违法,微信视频号小店,网站建设需求调研方法,毕业设计代做网站都可信么使用 Truffle 和 Ganache 搭建本地以太坊开发环境并部署一个简单智能合约的详细步骤: 一、环境搭建 安装 Node.js 和 npm Node.js 是一个基于 Chrome V8 引擎的 JavaScript 运行时环境,npm 是 Node.js 的包管理器。可以从 Node.js 官方网站下载安装程序…

使用 Truffle 和 Ganache 搭建本地以太坊开发环境并部署一个简单智能合约的详细步骤:

一、环境搭建

  1. 安装 Node.js 和 npm

    • Node.js 是一个基于 Chrome V8 引擎的 JavaScript 运行时环境,npm 是 Node.js 的包管理器。可以从 Node.js 官方网站下载安装程序,建议选择 LTS(Long-Term Support)版本。

    • 安装完成后,在命令行中运行以下命令验证安装是否成功

      node -v
      npm -v
  2. 安装 Truffle

    • Truffle 是一个用于以太坊开发的框架,提供了一套工具和库,帮助开发者更轻松地开发、测试和部署智能合约。在命令行中运行以下命令安装 Truffle

      npm install -g truffle
  3. 安装 Ganache

    • Ganache 是一个用于本地开发和测试以太坊应用程序的个人区块链,提供了一个模拟的以太坊网络环境。可以从 Ganache 官网下载安装文件。

    • 安装完成后,启动 Ganache,它会默认在本地创建一个开发用的区块链网络,通常监听 http://127.0.0.1:7545

二、创建项目并编写智能合约

  1. 创建项目目录并初始化

    • 创建一个新的项目目录,并初始化 Truffle 项目

      mkdir mydapp
      cd mydapp
      truffle init
    • 这将生成项目模板文件,包括 contractsmigrationstest 目录,以及 truffle-config.js 配置文件。

  2. 编写智能合约

    • contracts 目录下创建一个新的 Solidity 智能合约文件,例如 SimpleStorage.sol,并编写以下代码:

      solidity
      // SPDX-License-Identifier: MIT
      pragma solidity ^0.8.0;contract SimpleStorage {uint public storedData;function set(uint x) public {storedData = x;}function get() public view returns (uint) {return storedData;}
      }
    • 这个合约包含一个 set 函数用于存储数据,一个 get 函数用于获取存储的数据。

三、配置 Truffle 并部署智能合约

  1. 更新 Truffle 配置文件

    • 打开 truffle-config.js 文件,修改网络配置以连接到 Ganache:

      JavaScript
      module.exports = {networks: {development: {host: "127.0.0.1",port: 7545,network_id: "*" // Match any network id}},solc: {optimizer: {enabled: true,runs: 200}}
      };
    • 确保 hostportnetwork_id 与 Ganache 的配置一致。

  2. 创建迁移脚本

    • migrations 目录中创建文件 2_deploy_contracts.js,内容如下:

      JavaScript
      var SimpleStorage = artifacts.require("./SimpleStorage.sol");module.exports = function(deployer) {deployer.deploy(SimpleStorage);
      };
    • 这个脚本告诉 Truffle 如何部署 SimpleStorage 合约。

  3. 编译和部署智能合约

    • 在项目根目录下运行以下命令编译智能合约

      truffle compile
    • 编译成功后,运行以下命令部署智能合约到 Ganache

      truffle migrate
    • 如果一切正常,你将看到合约部署成功的消息,包括合约地址。

四、与智能合约交互

  1. 使用 Truffle 控制台与合约交互

    • 启动 Truffle 控制台

      truffle console
    • 获取合约实例

      SimpleStorage.deployed().then(function(instance) { app = instance; });
    • 获取账户列表

      web3.eth.getAccounts().then(accounts => {console.log(accounts);
      });
    • 设置存储值

      web3.eth.getAccounts().then(accounts => {app.set(42, { from: accounts[0] });
      });
    • 获取存储值

      app.get().then(function(value) { console.log(value.toString()); });
    • 这将设置存储值为 42,并获取存储的值。

  2. 使用 Web3.js 与合约交互

    • 创建一个名为 interact.js 的文件,并用以下代码填充它:

      JavaScript
      const { Web3 } = require('web3');
      const fs = require('fs');
      const path = require('path');const web3 = new Web3('http://127.0.0.1:7545');// 加载合约的 ABI 和字节码
      const contractData = require('./build/contracts/SimpleStorage.json');
      const abi = contractData.abi;
      const bytecode = contractData.bytecode;// 创建合约实例
      const myContract = new web3.eth.Contract(abi);async function interact() {try {// 获取账户列表const accounts = await web3.eth.getAccounts();console.log('Accounts:', accounts);// 部署合约const contract = await myContract.deploy({ data: bytecode }).send({ from: accounts[0], gas: 1000000 });console.log('Contract deployed at address:', contract.options.address);// 调用合约方法await contract.methods.set(42).send({ from: accounts[0] });const value = await contract.methods.get().call();console.log('Stored value:', value);} catch (error) {console.error('Error:', error);}
      }interact();
    • 运行以下命令与合约交互

      node interact.js

通过以上步骤,你就可以使用 Truffle 和 Ganache 搭建本地以太坊开发环境,并部署和交互一个简单的智能合约。

http://www.dtcms.com/wzjs/481145.html

相关文章:

  • 科技局网站建设方案苏州seo
  • h5免费建站浙江网络推广
  • 外国人做的篆字网站搜索引擎优化的方法和技巧
  • 个人微信网站怎么做友情链接方面pr的选择应该优先选择的链接为
  • 做网站技术服务费属于什么科目论文收录网站有哪些
  • 可信网站认证有用7个经典软文营销案例
  • 中国建设教育协会官方网站查谷歌seo排名工具
  • 《水利建设与管理》杂志社网站经典软文文案
  • 手机wap网站制作免费网络推广软件有哪些
  • 安阳+网站建设山西seo和网络推广
  • 镇江整站优化大连seo关键词排名
  • 龙华新区网站制作网站怎么营销推广
  • 中山做网站哪家公司好免费的网站推广方法
  • 苏州市政府网站建设评估网络营销专业学什么
  • wordpress用户名支持中文优化网站首页
  • 专业企业网站开发app开发软件
  • 佛山网站设计外包推广策划
  • 搭建网站源码引流推广网站
  • 做电子外贸网站建设qq营销软件
  • 日本做外贸网站设计网络营销专业学什么
  • 东莞做一个企业网站要多少钱怎么做盲盒
  • 长春互联网公司排名苏州百度 seo
  • 最牛的网站建设成人技能培训
  • 保定网站公司那家好百度推广seo优化
  • 中山营销型网站建设百度搜索关键词排名靠前
  • 百度提交wordpress长沙seo服务哪个公司好
  • 建个网站能赚钱吗微营销平台有哪些
  • 浙江网站建设费用重庆百度seo
  • 龙华民治网站建设公司深圳百度推广
  • 网站php源码web成品网站源码免费