11. 建立你的第一个Web3项目

ops/2024/9/18 6:20:58/ 标签: web3

11. 建立你的第一个Web3项目

在这一部分,我们将带你一步步地建立一个简单的Web3项目,从环境搭建到智能合约的创建与部署,再到开发一个去中心化应用(dApp)并与智能合约交互。这是你迈向Web3开发的第一步。

1. 环境搭建与工具准备

在开始Web3开发之前,需要搭建适合的开发环境,并安装一些常用的开发工具。

1.1 安装Node.js和npm

Node.js是一个基于JavaScript的运行时环境,npm是其默认的包管理器。在Web3开发中,Node.js和npm是必不可少的工具。

  • 安装Node.js
    • 访问Node.js官网并下载最新的LTS版本。
    • 安装后,通过命令行检查安装是否成功:
      node -v
      npm -v
      
1.2 安装Truffle和Ganache

Truffle是一个开发、测试和部署智能合约的框架,Ganache是一个本地的以太坊区块链模拟器,用于在本地测试智能合约。

  • 安装Truffle

    npm install -g truffle
    
  • 安装Ganache

    • 你可以通过Ganache官网下载桌面版,或通过命令行安装CLI版:
      npm install -g ganache-cli
      
1.3 安装MetaMask

MetaMask是一个以太坊钱包,允许你在浏览器中与dApp交互。它充当你的数字钱包,并能连接到本地或远程的以太坊网络。

  • 安装MetaMask
    • 访问MetaMask官网,下载并安装适用于你浏览器的扩展插件。
    • 安装后,创建一个新钱包并保存助记词。
2. 创建和部署一个简单的智能合约

接下来,我们将编写一个简单的智能合约,并将其部署到本地的以太坊区块链(Ganache)上。

2.1 初始化Truffle项目

首先,我们需要创建一个新的Truffle项目。

  1. 创建项目文件夹

    mkdir my-first-web3-project
    cd my-first-web3-project
    
  2. 初始化Truffle项目

    truffle init
    
2.2 编写智能合约

我们将编写一个简单的智能合约,用于存储和检索一条消息。

  1. 创建智能合约文件

    • contracts文件夹下创建一个名为SimpleStorage.sol的文件,内容如下:
      // SPDX-License-Identifier: MIT
      pragma solidity ^0.8.0;contract SimpleStorage {string private message;// 设置消息function setMessage(string memory newMessage) public {message = newMessage;}// 获取消息function getMessage() public view returns (string memory) {return message;}
      }
      
  2. 编译智能合约

    • 在项目根目录下运行以下命令来编译合约:
      truffle compile
      
2.3 部署智能合约

将智能合约部署到本地的以太坊区块链(Ganache)上。

  1. 配置网络

    • truffle-config.js文件中,配置本地的Ganache网络:
      module.exports = {networks: {development: {host: "127.0.0.1",     // 本地主机地址port: 7545,            // Ganache默认端口network_id: "*",       // 匹配任何网络ID},},// 其他配置...
      };
      
  2. 编写部署脚本

    • migrations文件夹中创建一个名为2_deploy_contracts.js的文件,内容如下:
      const SimpleStorage = artifacts.require("SimpleStorage");module.exports = function(deployer) {deployer.deploy(SimpleStorage);
      };
      
  3. 启动Ganache

    • 打开Ganache应用或通过命令行启动:
      ganache-cli
      
  4. 部署智能合约

    • 在项目根目录下运行以下命令,将合约部署到Ganache:

      truffle migrate
      
    • 成功部署后,Truffle会显示智能合约的部署地址。

3. 开发一个dApp并与智能合约交互

现在,我们将开发一个简单的dApp,用户可以通过该应用与部署的智能合约进行交互。

3.1 设置前端开发环境

在项目中创建一个client文件夹,用于存放前端代码。

  1. 初始化前端项目

    mkdir client
    cd client
    npm init -y
    
  2. 安装依赖

    • 安装Web3.js库和其他前端依赖:
      npm install web3
      npm install lite-server --save-dev
      
  3. 创建前端文件

    • client文件夹中创建一个index.html文件,内容如下:

      <!DOCTYPE html>
      <html lang="en">
      <head><meta charset="UTF-8"><meta name="viewport" content="width=device-width, initial-scale=1.0"><title>My First Web3 dApp</title>
      </head>
      <body><h1>Simple Storage dApp</h1><input type="text" id="messageInput" placeholder="Enter a message" /><button id="setMessageButton">Set Message</button><p>Stored Message: <span id="storedMessage"></span></p><script src="https://cdn.jsdelivr.net/npm/web3/dist/web3.min.js"></script><script src="app.js"></script>
      </body>
      </html>
      
    • 创建app.js文件,用于与智能合约进行交互,内容如下:

      const web3 = new Web3(Web3.givenProvider || "http://localhost:7545");const contractAddress = "YOUR_CONTRACT_ADDRESS";  // 部署的合约地址
      const contractABI = [// ABI goes here...
      ];const contract = new web3.eth.Contract(contractABI, contractAddress);document.getElementById('setMessageButton').onclick = async () => {const message = document.getElementById('messageInput').value;const accounts = await web3.eth.getAccounts();await contract.methods.setMessage(message).send({ from: accounts[0] });alert('Message stored successfully');
      };const loadMessage = async () => {const message = await contract.methods.getMessage().call();document.getElementById('storedMessage').innerText = message;
      };loadMessage();
      
    • 将部署时生成的智能合约ABI复制到app.js中的contractABI变量中,并替换contractAddress为实际的合约地址。

3.2 运行dApp
  1. 启动开发服务器

    • client文件夹中,运行以下命令启动轻量级开发服务器:
      npx lite-server
      
  2. 在浏览器中访问dApp

    • 浏览器将自动打开并显示你的dApp。你可以在输入框中输入消息并点击“Set Message”按钮,将消息存储到智能合约中。
  3. 与智能合约交互

    • 输入消息并提交后,dApp会与智能合约进行交互,将消息存储到区块链中。页面将自动显示存储的消息。

总结

通过本章节的实践,你已经了解了如何搭建Web3开发环境,编写和部署智能合约,以及开发一个与智能合约交互的dApp。这是Web3开发的基础技能,未来你可以在此基础上开发更复杂的去中心化应用。

  • 环境搭建与工具准备:熟悉Truffle、Ganache、MetaMask等Web3开发工具,并搭建好开发环境。
  • 创建和部署智能合约:学习了如何编写简单的Solidity智能合约,并将其部署到本地以太坊区块链上。
  • 开发dApp并与智能合约交互:开发了一个简单的Web3应用,用户可以通过该应用与智能合约交互,实现数据的存储和读取。

随着对Web3技术的深入理解,你可以进一步探索更复杂的合约逻辑、前端框架的集成,以及与不同区块链平台的互操作性,从而开发出功能丰富的去中心化


http://www.ppmy.cn/ops/109736.html

相关文章

java开发,记录一些注解和架构 pojo、entity、respository

最近接了一个项目&#xff0c;说是项目其实也不算是项目&#xff0c;因为是把这个项目赛到其他项目中的。 熟悉一些这个项目的功能&#xff0c;梳理了一下&#xff0c;在代码开发中主要关心pojo、entity、respository、controller、service。 在这里主要记录前3个的流程与作用…

使用OpenCV进行模糊检测(拉普拉斯算子)

参考&#xff1a; 使用OpenCV进行模糊检测&#xff08;拉普拉斯算子&#xff09; 代码&#xff1a; # import the necessary packages from imutils import paths import argparse import cv2 import osdef variance_of_laplacian(image):# compute the Laplacian of the ima…

[测试]1.TPC-DS性能测试

通过EMR运行基于OSS-HDFS服务的TPC-DS Benchmark了解数据查询和分析的性能表现_对象存储(OSS)-阿里云帮助中心 (aliyun.com) 鲲鹏大数据测试指导: 安装Git-部署环境配置-ElasticSearch组件测试工具Esrally 使用指导-测试指导-测试指导-鲲鹏BoostKit大数据使能套件开发文档-鲲…

【爬虫软件】小红书按关键词批量采集笔记,含笔记正文、转评赞藏等!

一、背景介绍 1.1 爬取目标 熟悉我的小伙伴都了解&#xff0c;我之前开发过2款软件&#xff1a; 【GUI软件】小红书搜索结果批量采集&#xff0c;支持多个关键词同时抓取&#xff01; 【GUI软件】小红书详情数据批量采集&#xff0c;含笔记内容、转评赞藏等&#xff01; 现在…

maven简介

1&#xff0c; 结构化管理项目 如果不用maven&#xff0c;研发拿到一个项目要去查看代码&#xff0c;了解其代码结构&#xff0c;了解其依赖文件&#xff0c;jar包位置&#xff0c;图片等文件存储路径等&#xff1b;而maven是规范地将对应的源代码、依赖文件等定义其固定位置&…

多用户B2B2C商城源码+短视频直播+APP+小程序+H5

店铺管理 店铺列表&#xff0c;新店铺审核&#xff0c;地址管理&#xff0c;服务管理&#xff0c;运费模版&#xff0c;品牌管理 订单监管 视频订单&#xff0c;拼团订单&#xff0c;评论管理&#xff0c;退款管理 装修商城 模版管理&#xff0c;页面管理&#xff0c;全局…

【Hot100】LeetCode—55. 跳跃游戏

目录 1- 思路贪心 2- 实现⭐55. 跳跃游戏——题解思路 3- ACM 实现 原题链接&#xff1a;55. 跳跃游戏 1- 思路 贪心 利用 cover 记录覆盖的范围&#xff0c;每次覆盖范围移动一步更新 cover 并比较大小&#xff0c;如果可以移动则更新 cover 2- 实现 ⭐55. 跳跃游戏——题解…

海康威视 嵌入式 面经 海康威视嵌入式软件 嵌入式硬件总结面试经验 面试题目汇总

标题海康威视 嵌入式 面经 海康威视嵌入式软件 嵌入式硬件总结面试经验 面试题目汇总 整理总结了海康威视嵌入式的面试题目&#xff01;&#xff0c;可以供大家面试参考 标题海康威视 嵌入式 面经 五月底投递&#xff0c;六月初面试&#xff0c;一场技术面&#xff0c;一场H…

Unity+LeapMotion2的使用

开始吧 导入步骤1.到官网下载软件并安装2.安装插件3.场景中添加检测管理器4.场景中添加手部模型 更多细节 导入步骤 1.到官网下载软件并安装 地址 重启电脑后连接设备 可以看到连接成功 2.安装插件 &#xff08;也可以看官方教程&#xff09; Project—>PackageManag…

备战秋招60天算法挑战,Day33

题目链接&#xff1a; https://leetcode.cn/problems/longest-increasing-subsequence/ 视频题解&#xff1a; https://www.bilibili.com/video/BV1RRvheFEog/ LeetCode 300. 最长递增子序列 题目描述 给你一个整数数组nums &#xff0c;找到其中最长严格递增子序列的长度。 …

JS笔记

9.10 1.对象 javascript中的对象分为3种&#xff1a;自定义对象&#xff0c;内置对象&#xff0c;浏览器对象 JavaScript 中的所有事物都是对象&#xff1a;字符串、数字、数组、日期&#xff0c;等等。 在 JavaScript 中&#xff0c;对象是拥有属性和方法的数据。 属性是与…

Spring Boot 四大请求编码模板(GET、POST、PUT、DELETE)

一、四大请求引入 1、GET 请求 通常用于请求资源 通常在路径中带参 在 Spring Boot 中&#xff0c;使用 GetMapping 或 RequestMapping(method RequestMethod.GET) 注解来映射请求方式与请求路径 使用 RequestParam 来映射请求参数 2、POST 请求 通常用于提交资源 通常…

ssm微信小程序的英语学习激励系统论文源码调试讲解

2 关键技术介绍 2.1 SSM框架 开发信息管理系统的主流框架是SSM&#xff08;Spring Spring MVC MyBatis&#xff09;&#xff0c;SSM框架web层使用Spring MVC框架&#xff0c;使传输前后端数据变得简单&#xff1b;对于业务层使用Spring作为轻量级控制反转和面向切面的容器框…

【css】获取最后一个li进行样式特殊处理

1.问题背景 有个列表&#xff0c;列表项之间有一段间隔。 2. 实现方案 每项列表项添加一个margin&#xff0c;最后一个元素不添加 你可以使用 CSS 的 :last-child 伪类选择器来选择列表中的最后一个 li 元素&#xff0c;并将其 margin-right 设置为 0&#xff0c;以达到最后…

android 生SHH,并配置

1. ssh-keygen -t rsa -b 4096 -C "XXXXxx.com" 2. vim ~/.ssh/config 新建一个文件&#xff1a;~/.ssh/config&#xff1a;并将下列的内容放入&#xff1a; Host * HostKeyAlgorithms ssh-rsa PubkeyAcceptedKeyTypes ssh-rsa 4.得到XXX.pub去添加ssh 5.克隆

开关电源EMI问题解决策略

开关电源作为现代电子设备中不可或缺的组成部分,其电磁干扰(EMI)问题一直是工程师们面临的重要挑战。 低频段EMI(1MHz以内)整改策略 在1MHz以内的频段,差模干扰占主导地位。针对这一特点,我们可以采取以下策略: a) 增大X电容:在输入端增加X电容可以有效降低差模干扰。 b) 添…

快速失败 (fail-fast) 和安全失败 (fail-safe)

1. 定义与工作原理 1.1 快速失败&#xff08;Fail-Fast&#xff09; 定义&#xff1a; 快速失败是一种系统设计原则&#xff0c;当系统遇到异常情况或错误时&#xff0c;立即停止执行并返回错误&#xff0c;而不是试图继续执行或处理潜在的问题。快速失败系统会主动检测系统中…

Spring面试

一、对Spring的理解 &#xff08;一&#xff09;Spring的发展史 &#xff08;二&#xff09;Spring的体系结构 &#xff08;三&#xff09;Spring相关组件 1.Spring和SpringMVC的关系 2.Spring和SpringBoot的关系 3.Spring和SpringCloud的关系 4.Spring和SpringSecurity的…

C#环境搭建和入门教程--vs2022之下

目录 1.环境搭建 2.先让程序跑起来 3.C#代码结构 4.变量&#xff0c;输入输出介绍 5.内容输入和类型转换 1.环境搭建 我们的这个c#基础学习主要就是在这个vs2022上面进行的&#xff0c;我们的这个c/c使用的都是这个平台 我们首先检查一下我们的这个环境是不是完全的配置了…

Python+requests接口自动化测试框架实例教程

前段时间由于公司测试方向的转型&#xff0c;由原来的web页面功能测试转变成接口测试&#xff0c;之前大多都是手工进行&#xff0c;利用postman和jmeter进行的接口测试&#xff0c;后来&#xff0c;组内有人讲原先web自动化的测试框架移驾成接口的自动化框架&#xff0c;使用的…