以太坊作为全球领先的智能合约平台,不仅仅是一种加密货币,更是一个去中心化的应用(DApp)开发平台,它允许开发者构建和运行无需信任第三方、公开透明、抗审查的应用程序,本教程将带你从零开始,逐步了解并实践如何制作一个简单的以太坊应用(DApp)。
了解基础知识:以太坊是什么?
在动手之前,我们需要对以太坊的核心概念有所了解:
- 区块链:以太坊是一个基于区块链技术的分布式账本,记录着网络上的所有交易和状态变更。
- 以太币 (ETH):以太坊网络的原生加密货币,用于支付交易费用(Gas费)和激励矿工。
- 智能合约 (Smart Contract):运行在以太坊区块链上的自动执行的程序代码,它们是DApp的后端逻辑,一旦部署就无法更改。
- 账户 (Accounts):分为外部账户(由用户私钥控制,如你的钱包)和合约账户(由智能代码控制)。
- 虚拟机 (EVM - Ethereum Virtual Machine):以太坊网络中执行智能合约的全球共享计算机。
- Gas:执行智能合约或交易时需要支付的计算费用,以防止无限循环和滥用网络资源。
开发环境搭建
开始开发前,你需要准备以下工具和环境:
- 代码编辑器:
- Visual Studio Code (VS Code):强烈推荐,安装其官方插件
Solidityby Juan Blanco,提供语法高亮、代码提示、编译等功能。
- Visual Studio Code (VS Code):强烈推荐,安装其官方插件
- Node.js 和 npm (Node Package Manager):
- 访问 Node.js 官网 下载并安装 LTS (长期支持) 版本,npm 会随 Node.js 一起安装。
- Truffle Suite:
- Truffle:最受欢迎的以太坊开发框架之一,用于智能合约的编译、测试、部署和管理。
- Ganache:一个个人以太坊区块链,用于快速创建和部署测试网络,你可以看到所有交易的详细信息,方便调试。
- 安装命令:打开终端或命令提示符,运行
npm install -g truffle ganache-cli,Ganache 也有图形界面版本,可以从其官网下载。
- MetaMask 钱包插件:
- 浏览器插件(Chrome, Firefox, Brave 等),用于与以太坊测试网络交互,管理你的测试账户和私钥。
- 从 MetaMask 官网 下载并安装,创建钱包并备份好助记词!
创建你的第一个以太坊项目
-
初始化项目:
- 在你的电脑上创建一个新的文件夹,
my-first-dapp,然后进入该文件夹。 - 在终端中运行
truffle init,这将创建一个标准的 Truffle 项目结构,包括:contracts/:存放你的 Solidity 智能合约文件。migrations/:部署脚本文件。test/:测试文件。truffle-config.js:Truffle 的配置文件。
- 在你的电脑上创建一个新的文件夹,
-
编写智能合约:
-
打开
contracts/文件夹,删除Migrations.sol(这是 Truffle 自带的,我们暂时用不到),然后创建一个新的 Solidity 文件,SimpleStorage.sol。 -
编写一个简单的智能合约,用于存储和读取一个数字:
// SPDX-License-Identifier: MIT pragma solidity ^0.8.0; contract SimpleStorage { uint256 private storedData; event DataUpdated(uint256 newValue); function set(uint256 x) public { storedData = x; emit DataUpdated(x); } function get() public view returns (uint256) { return storedData; } } -
代码解释:
SPDX-License-Identifier和pragma solidity是 Solidity 合约的标准开头。contract SimpleStorage { ... }定义了一个名为SimpleStorage的合约。uint256 private storedData;声明一个私有的无符号256位整型变量storedData。event DataUpdated(uint256 newValue);定义一个事件,用于在数据更新时通知前端。function set(uint256 x) public:一个公共函数,用于设置storedData的值,并触发DataUpdated事件。function get() public view returns (uint256):一个公共视图函数,用于读取storedData的值,view表示它不会修改链上状态。
-
-
编译智能合约:
- 确保你的
truffle-config.js文件已经正确配置(Truffle 初始化后会默认配置好)。 - 在终端中运行
truffle compile,如果成功,你会在build/contracts/目录下看到编译后的合约 ABI(应用程序二进制接口)和字节码。
- 确保你的
-
部署智能合约 (测试):
-
启动 Ganache:
- 如果你安装的是 Ganache CLI,在终端运行
ganache-cli(确保另一个终端窗口在项目根目录)。 - 如果你使用的是 Ganache GUI,打开它,创建一个新的工作区,选择 "QUICKSTART" 或自定义一个区块链。
- 记下 Ganache 提供的其中一个测试账户地址和私钥(通常以 0x 开头)。
- 如果你安装的是 Ganache CLI,在终端运行
-
配置 MetaMask:
- 打开 MetaMask,点击网络选择器,选择 "Custom RPC"。
- 在 "New RPC URL" 中输入 Ganache 的 RPC URL(通常是
HTTP://127.0.0.1:7545或HTTP://localhost:7545,具体看 Ganache 界面显示)。 - 网络名称可以填写 "Ganache Testnet",链 ID 输入 Ganache 显示的链 ID(通常是 1337 或 5777)。
- 点击 "保存"。
-
导入 Ganache 测试账户到 MetaMask:

-