优惠论坛

标题: 怎么发行自己的加密货币? [打印本页]

作者: g9527    时间: 2025-9-7 20:09
标题: 怎么发行自己的加密货币?
本文章详细的讲解一个最基础的链上加密货币发行过程,期间也需要利用到几个工具(当然本文章最后有一键发行的工具,嫌麻烦的可以直接翻到最后使用工具)标准流程全解析5 U/ s7 w6 F( s; g. q4 s6 s* W
以太坊代币(ERC‑20)从开发到上链的最简标准流程(只讲开发与发行)示例使用以太坊兼容链 + Hardhat + OpenZeppelin,先部署到测试网(Sepolia),确认无误后再部署主网。/ B) A' [. {# O$ t+ m3 Z
一、环境准备; T" z( H5 p3 w6 ?
- 必备6 l$ e$ Q7 n$ U1 p5 ~
- ≥ 18 与 npm
" ~% x. N9 a. `5 Q5 a) o  Y6 ?- 一个以太坊钱包(如 MetaMask)
# S) m6 Q! q9 C3 f- 测试网 ETH(Sepolia Faucet 获取),主网部署需主网 ETH$ T% X0 r( r+ q' t
- RPC 节点(Alchemy/Infura/Ankr 等均可)7 d, y/ D* k* Y0 z
- 新建项目目录,例如:erc20-token,并进入该目录
% E# D# U. A" Z7 p8 y二、安装与初始化
$ e4 d6 c. j6 j- 初始化项目/ T& y( m0 e1 |- }) `
- npm init -y
& H0 L) v0 {; P3 K! z+ H- 安装依赖
' d" a! \+ C& Q5 `% b. f- A7 [  D( M- 开发工具:npm i -D hardhat @4 t8 Y! d$ \. W. e* i
nomicfoundation/hardhat-toolbox dotenv
9 @: ?8 n. X1 Z- 合约库:npm i @openzeppelin/contracts% b! Q5 W8 ^5 G7 l- `' e
- 初始化 Hardhat(可交互,也可手动建文件)* R( a, r+ L3 h  j5 F5 B6 ^
- 交互方式:npx hardhat(选择 JavaScript 项目)% T) \4 t# [' R# d) b) q% ?
- 或手动创建以下文件(见下一步)* u- Z( ?5 y. i$ F1 \
三、最小化项目结构与配置' {- N8 K; P2 Z& ]- `& L' d2 Z
- 新建 (最小可用配置)$ b9 Z  z+ ^; }/ V8 |
- 内容示例:
( ~1 ^0 A! D( y4 _- \9 X+ `- require("@nomicfoundation/hardhat-toolbox");
8 `! o7 e  n8 i0 `  f% l- require("dotenv").config();
8 S- v  C& i( ?/ W: ~- = {# J) V. W  {8 o7 u$ Z) U
solidity: "0.8.24",
0 X* L% i0 N4 q" G% Tnetworks: {
0 r3 w4 W/ P$ K; F. D1 O: B+ bsepolia: {
( P) n* i  m9 Z' b$ d" G, ~( i# burl: .SEPOLIA_RPC_URL,
+ a6 T, S" u1 qaccounts: [.PRIVATE_KEY].filter(Boolean),
5 \" m4 Q# J7 s) w9 d4 G2 A/ y},' j, n* W# M9 f- y* d0 F
// mainnet: { url: .MAINNET_RPC_URL, accounts: [.PRIVATE_KEY].filter(Boolean) }) ~4 l. P  d; M
},
: `# {9 ], V( H. x! o2 p! tetherscan: {) i+ y/ j! z" N2 v5 }7 e. Q4 ^
apiKey:
- b. H( O: L* U# q; O+ q.ETHERSCAN_API_KEY, // 可选:用于合约校验! p" X; p1 }# b
},+ [$ W% k5 Y/ }7 C
};
9 k. @" B4 q1 d- 在项目根目录创建 .env,示例(请替换为你自己的值):  t0 A8 V: X. Y
- SEPOLIA_RPC_URL=
1 {" U0 A8 {- F  m8 }, K6 d- MAINNET_RPC_URL=2 U/ ^+ A) |/ T. R% o4 P5 c
- PRIVATE_KEY=你的私钥(0x开头,无空格)3 S7 K; X) p% i7 o4 O$ M; t
- ETHERSCAN_API_KEY=你的Etherscan API Key(可选,用于校验)* ~- A( H2 M. u- j1 v$ V' w5 l7 A: Q
四、编写标准 ERC‑20 合约
5 A& {  n( Z. q- 在 contracts/ 目录下创建 ,示例代码:
% V( p; I# m) Q( Y4 ^2 t1 W+ _6 U- pragma solidity ^0.8.20;
% k& ?) X; M' G) {7 E; P5 @- import "@openzeppelin/contracts/token/ERC20/";
8 l% l% T1 f/ Y$ m$ h7 F, p- contract MyToken is ERC20 {2 S3 B2 _$ ^" T' Y; ?0 c
constructor(uint256 initialSupply) ERC20("MyToken", "MTK") {
) Y. [5 L3 G- j7 U3 r_mint(, initialSupply);+ S, u) V) S( ]% ^1 |
}
& ]# L; W# h" |& f2 n- o+ w8 o$ O}
: I' F* t( s( @1 k/ R9 }4 v- 说明6 t+ s. c$ p# e# r$ e
- 名称与符号可自定义(如 "MyToken" / "MTK")
+ |  I6 L$ |8 M7 |) x, s- initialSupply 为初始发行量(单位为最小单位 Wei,例如 18 位小数的代币需乘 10^18)4 R; g# c4 }/ g, k$ o
五、编写部署脚本1 P+ q! H  b4 X
- 在 scripts/ 目录下创建 ,示例代码:) l1 R1 C9 {6 H# Z
- const { ethers } = require("hardhat");3 U/ C! @. k) Z2 ^+ i" u
- async function main() {7 a$ ]  I$ ^7 d8 Y* [, u+ W# d
const initialSupply = ("100000000", 18); // 1亿枚,18位小数
7 B& m8 \7 t5 Y* w' }const token = await ("MyToken", [initialSupply]);6 r. `7 i. _7 f6 ~0 G+ i3 @6 t
await ();0 t9 n5 O; `' O! r! S" F7 g/ B
("MyToken deployed to:", );6 ^4 p* \: X# T% \( f2 U5 ~) g
}
/ D# R; m, [. A1 K( F- main().catch((error) => {: e+ O1 h; z# N9 J
(error);* y4 N' L7 H' p% H8 n8 F: D
= 1;
5 |8 D/ R2 Q- v# s});, j; [$ h5 V/ i, X5 `; G; @5 G; C0 u
六、编译与部署到测试网(Sepolia)
3 _+ V* {" d5 V: }* D2 @- 编译:npx hardhat compile0 M7 G2 K1 Z# x2 i. \. f: t2 p5 F
- 部署:npx hardhat run scripts/ --network sepolia7 @) T) q, a9 m) w& S3 x
- 运行成功会输出合约地址(MyToken deployed to: 0x...)
- M# Z& ~5 j/ P+ F! \; n6 Q( d- 在区块浏览器()查询该地址,确认合约已上链' L7 k& W+ ?, v' _8 f
七、可选:合约源码校验(便于他人查看源码与构造参数)
# m$ n6 L: c: e- 命令:npx hardhat verify --network sepolia 合约地址 初始发行量(Wei)$ K* z- x0 {1 B- d: g6 H2 h
- 例:npx hardhat verify --network sepolia 0xYourTokenAddress
% P) f9 A. |4 ^: \0 P: a9 X4 X. b0 ~1000000000000000000000000000 @1 Y$ m+ ~& E9 a" J. t
- 注意:这里的初始发行量需与部署脚本中的 initialSupply 完全一致(单位为 Wei)
0 t+ c) m+ ]9 ^1 J八、在钱包中查看代币
: O9 `7 @. P8 ?" N- 打开 MetaMask,选择对应网络(Sepolia 或主网)
- c2 v8 E" d9 R1 _- 选择“导入代币”,粘贴合约地址,确认代币符号与小数位(18)
1 X5 p7 H' L& `7 h; ]3 M. N! r7 w- 即可在钱包中看到初始发行的代币余额(在部署账户下)- w" U2 x) A% ~& n
九、部署到主网(可选)2 C8 N! A7 g' ~7 S2 P; T# f9 Z8 Z  w
- 确保 .env 中配置 MAINNET_RPC_URL、PRIVATE_KEY,且钱包内有主网 ETH
2 f5 F3 D9 q' z4 ^- 命令:npx hardhat run scripts/ --network mainnet! I( H. n3 R" @( B' x( B/ X( V0 X
- 可用 Etherscan 校验:npx hardhat verify --network mainnet 合约地址 初始发行量(Wei)
8 a4 T: H! w, j- `# P十、常见问题与排查
# ~6 n& c' p* U' l/ G% `. f- 部署报“insufficient funds for gas”:- s1 h! R5 c" f8 E- _+ o7 P
- 账户没有足够 ETH(测试网/主网),先充值再部署% Q8 j2 i: Y- q& F6 H
- Ethers 版本导致的方法差异:
% p1 i5 X3 D4 c& k, j8 X) z0 S- 本教程基于 ethers v6(Hardhat Toolbox 默认),使用 % |4 ]4 C7 q( Y6 j0 J
- 私钥与 .env:
3 x5 q1 x8 @9 Z1 ]3 y& w% B# b- PRIVATE_KEY 必须以 0x 开头,无引号与空格
2 j' t2 s( h* C4 U9 O' T- 确保 .gitignore 排除 .env,切勿泄露私钥
4 T, Q" p0 s1 N3 o. D- 构造参数不一致导致校验失败:
% Z( F9 k1 K6 F% b2 w' v- verify 命令的初始发行量(Wei)必须与部署时完全一致$ c  b) S; n7 t7 s7 I5 a
到这里,你已经完成了一个标准 ERC‑20 代币从“编写 → 编译 → 部署 →(可选)校验 → 钱包查看”的完整最小流程。若你需要把名称/符号/小数位做成可配置,或加入可增发/销毁、暂停等扩展权限。8 U1 n7 c8 `! P  L, [+ S3 t9 E
下面是一键发币的工具;
. H+ j* @0 c  I. c, s: g/ l这个星辰发币是目前最好用的一个一键发币的工具( ),不需要授权,代码干净;最推荐。. X- @3 J+ p2 |9 Y
这个dajgh也还可以但是需要授权( ),授权会带来一些安全方面的风险。
; A+ ]6 v4 G% y, H
作者: g9527    时间: 2025-9-7 20:30
这玩意儿整起来还挺麻烦啊,不过一键发行工具倒是省事,懒人直接冲就完事了
作者: 万家灯火    时间: 2025-9-7 22:31
推荐多半都有胜负,大家还是要平定心态
作者: leconer    时间: 2025-9-7 22:32
按照惯例来看看今天的推荐怎么样的了
作者: 小夏Sherry    时间: 2025-9-7 22:33
推荐学得再多,不如自己执行更好
作者: hong29    时间: 2025-9-7 22:41
是很好的,也是为数不多可以使用的钱包
作者: stareshiny    时间: 2025-9-7 22:41
这个方法可以自己好好利用,也是很不错的。
作者: 一帆风顺发    时间: 2025-9-7 22:44
今次方法在这里的运气还是值得肯定的.
作者: 星星知我心    时间: 2025-9-7 22:44
方法最后一段话觉得是很有道理的,但是在我面前就难以实现,毕竟运程太差了。
作者: 林武风    时间: 2025-9-7 22:45
今次方法能有盈利一天的生活费我也满足了。
作者: 南相楚    时间: 2025-9-7 22:53
钱包一般确实是会选择能够相信的啊
作者: 不傻不成气候    时间: 2025-9-7 22:55
这一次方法也还是超级好的赢来的啊
作者: wuzhaoshichao    时间: 2025-9-7 23:01
每种方法也是值得去看看关注下的啦。
作者: 老龙口    时间: 2025-9-7 23:02
这个钱包我还真是没有了解到的.
作者: jslinen    时间: 2025-9-7 23:12
这个也是可以看看大家推荐的钱包了的!
作者: 我的花园    时间: 2025-9-7 23:18
这个推荐瞅起来还好,有必要的话能够跟。
作者: 强强强123    时间: 2025-9-7 23:19
胜利的时候就该走,全部方法长玩就是输
作者: 老衲来了    时间: 2025-9-7 23:22
其实各个方法的吧~这个也是留意一下了
作者: 赌神归来    时间: 2025-9-7 23:26
看了这个方法我感到也是需要了解起来了的哦。
作者: 大吉大利    时间: 2025-9-7 23:27
推荐也是要看情况的,这个应该挺好
作者: 百战    时间: 2025-9-7 23:33
推荐也是要看情形的,这个应该挺好
作者: 知行合一    时间: 2025-9-7 23:36
推荐必定有对和不对的,因此老哥们还是要本身把握
作者: 想要水果机    时间: 2025-9-7 23:38
是很好的,也是为数不多可以用的钱包
作者: 小梦    时间: 2025-9-7 23:38
每一种方法也是值得去看看关心下的啦。
作者: 丁小荷    时间: 2025-9-7 23:41
今次方法可行赚到一天的生活费我也满足了。
作者: 洋森    时间: 2025-9-7 23:41
老哥的这波推荐胜负不了解高不高。
作者: wodezhuanyong    时间: 2025-9-7 23:43
使用这个方法有胜利还是最好的结果了呀。
作者: linxiaoshan888    时间: 2025-9-7 23:45
其实各种方法的吧~这个也是关心一下了
作者: 心随你动    时间: 2025-9-7 23:46
还是需要选有实力的钱包去交易哦。
作者: gkfbuw    时间: 2025-9-7 23:47
这个钱包不错使用,反正吧都是要谨慎安全第一啊!
作者: liuxin960    时间: 2025-9-7 23:50
钱包一般肯定是会选择能够相信的啊
作者: anzizhong    时间: 2025-9-7 23:52
我也希望大家多多出来做推荐,有福利大家一起共享
作者: yumi666    时间: 2025-9-7 23:56
还行啊,现在我也是用这个钱包
作者: ouliangzhong    时间: 2025-9-7 23:59
这个也是能看看楼主推荐的钱包了的!
作者: xiaoyi    时间: 2025-9-8 00:00
这个推荐看起来还好,有必要的话能够跟。
作者: drogan    时间: 2025-9-8 00:01
这一次方法也还是很好的盈利来的啊
作者: 小希哥    时间: 2025-9-8 00:02
这个钱包我还真的不了解到的.
作者: mxsj2016k    时间: 2025-9-8 00:03
钱包这么多,到底选择哪一个确实不容易。
作者: 中大奖    时间: 2025-9-8 00:04
推荐学得再多,干脆亲自执行更好
作者: 一路顺风    时间: 2025-9-8 00:06
见到这个方法我认为也是要关心起来了的哦。
作者: 越前龙马    时间: 2025-9-8 00:10
我也来学校这个推荐会怎么样了。
作者: 不要脸最大    时间: 2025-9-8 00:11
有盈利的时候就该走,全部方法长玩就是输
作者: bishao    时间: 2025-9-8 00:13
这个方法需要自己好好把握,也是很不错的。
作者: 不洗脸都帅    时间: 2025-9-8 00:13
推荐多半都有输赢,大家还是要放平心情
作者: 高文胜    时间: 2025-9-8 00:16
菠菜必须有推荐,这是不可或缺的
作者: 护国石柱    时间: 2025-9-8 00:19
按照习惯来看看今天的推荐如何的了
作者: lvaeyou    时间: 2025-9-8 00:23
方法最后一段话觉得是实用的,但是在我面前就难以实现,毕竟时运太差了。
作者: 春娇与小智    时间: 2025-9-8 00:24
今次方法在这里的运气还是值得肯定的.
作者: Lhrlhrgo    时间: 2025-9-8 00:29
钱包也不用那么多,有一个就可以的了。
作者: 22301    时间: 2025-9-8 08:23
这个也是可以去关注起来的啊。
作者: 舞出精彩    时间: 2025-9-8 13:32
这是要在看一下是怎么发的呢
作者: rainwang    时间: 2025-9-8 16:12
这个需要有资格吧,个人是不可能的吧




欢迎光临 优惠论坛 (https://tcelue.co/) Powered by Discuz! X3.1