优惠论坛
标题:
怎么发行自己的加密货币?
[打印本页]
作者:
g9527
时间:
2025-9-7 20:09
标题:
怎么发行自己的加密货币?
本文章详细的讲解一个最基础的链上加密货币发行过程,期间也需要利用到几个工具(当然本文章最后有一键发行的工具,嫌麻烦的可以直接翻到最后使用工具)标准流程全解析
, W- Q! Z$ [) B" ~: l
以太坊代币(ERC‑20)从开发到上链的最简标准流程(只讲开发与发行)示例使用以太坊兼容链 + Hardhat + OpenZeppelin,先部署到测试网(Sepolia),确认无误后再部署主网。
, f6 ~, [7 {9 p8 S9 n# f
一、环境准备
0 @" m$ m/ ^3 e/ ]% J# S
- 必备
# _1 w2 S: }) ^+ f) L
- ≥ 18 与 npm
' ?6 v/ y6 n, K# K2 P! K+ a
- 一个以太坊钱包(如 MetaMask)
]6 F6 i% R: i* _
- 测试网 ETH(Sepolia Faucet 获取),主网部署需主网 ETH
0 ~$ i$ o; `5 A0 H) N
- RPC 节点(Alchemy/Infura/Ankr 等均可)
+ W! ~" |2 j% }3 k/ B6 g. U2 C/ f
- 新建项目目录,例如:erc20-token,并进入该目录
2 X8 ^+ B, X8 R7 \
二、安装与初始化
0 l( l. k5 g, g9 L
- 初始化项目
9 G* A- {( x$ T
- npm init -y
2 x4 J ~' d$ P( X9 T; S
- 安装依赖
5 A) t- L# Q( A/ x, n$ k1 J" M
- 开发工具:npm i -D hardhat @
8 {7 Z3 ?4 M$ E' h4 X
nomicfoundation/hardhat-toolbox dotenv
) j7 x7 D4 d1 o" k7 v
- 合约库:npm i @openzeppelin/contracts
$ ?# z0 v4 E4 p! o: \: E: J
- 初始化 Hardhat(可交互,也可手动建文件)
( f9 W# B3 D9 L* j
- 交互方式:npx hardhat(选择 JavaScript 项目)
, V+ Q: w& b s; I$ Z7 @" H
- 或手动创建以下文件(见下一步)
1 R2 ]: O3 T, D7 y9 F9 K
三、最小化项目结构与配置
/ B6 l1 [+ x3 d. U8 c; ]
- 新建 (最小可用配置)
3 K! L% t6 p% j% n- S
- 内容示例:
" y% O$ g1 E& T
- require("@nomicfoundation/hardhat-toolbox");
) x! e- g# R: J, C- P
- require("dotenv").config();
7 h# V% I3 g1 {" `. {7 K
- = {
0 \2 j2 ] | }( w1 h5 y2 y
solidity: "0.8.24",
# I' Y9 B* X7 G! Z U8 `/ H7 d, B* x
networks: {
0 ~: M2 J# q7 I( C4 F, j
sepolia: {
( h7 l9 G+ H# |: A3 L9 `# J
url: .SEPOLIA_RPC_URL,
7 |% w3 q& ^; ?/ h, i0 ^
accounts: [.PRIVATE_KEY].filter(Boolean),
+ n% k( J3 E& D9 L
},
' V; m+ V: u% R
// mainnet: { url: .MAINNET_RPC_URL, accounts: [.PRIVATE_KEY].filter(Boolean) }
- c+ |$ B& B% U& P
},
) y7 h) {7 t5 V3 T6 \. P
etherscan: {
- o' N; i4 h1 d
apiKey:
' i6 Z0 R" c n( ^7 j1 _( d
.ETHERSCAN_API_KEY, // 可选:用于合约校验
4 @( ^. L7 V3 \1 r( m, s7 q
},
S/ W" o) {: E7 n
};
; }7 P( U- }+ R# E1 }. `
- 在项目根目录创建 .env,示例(请替换为你自己的值):
* j" \) `4 ^+ k6 B f
- SEPOLIA_RPC_URL=
# Y [; V3 ?5 F7 t
- MAINNET_RPC_URL=
* i d1 T4 E2 y
- PRIVATE_KEY=你的私钥(0x开头,无空格)
# C7 e: t4 \/ p0 J6 q) v
- ETHERSCAN_API_KEY=你的Etherscan API Key(可选,用于校验)
" X# N4 M% P7 ^+ D v# h: B
四、编写标准 ERC‑20 合约
. S" R+ C% X$ J9 ]# o
- 在 contracts/ 目录下创建 ,示例代码:
- ~7 x- _ p4 x
- pragma solidity ^0.8.20;
8 e9 p; o3 E# ?* l5 \- @
- import "@openzeppelin/contracts/token/ERC20/";
( z# Z3 H* H* B* |8 o; k' W
- contract MyToken is ERC20 {
( b1 m. ]0 m' l. ?4 P
constructor(uint256 initialSupply) ERC20("MyToken", "MTK") {
: o9 Z6 Y1 Z3 M* k! w
_mint(, initialSupply);
4 q' W0 T$ ?7 i* J( g6 E* ?
}
# r) V: `; V9 Z5 M: M) K
}
5 L1 t# V1 x4 B& Z7 X
- 说明
" j" ?7 `/ G; C# o+ J$ x
- 名称与符号可自定义(如 "MyToken" / "MTK")
. e$ q1 X! v5 }: K
- initialSupply 为初始发行量(单位为最小单位 Wei,例如 18 位小数的代币需乘 10^18)
8 d2 k5 [/ U1 h0 I' H+ t+ B
五、编写部署脚本
9 G* R+ ]: |+ D, _( C
- 在 scripts/ 目录下创建 ,示例代码:
! j' v* D4 A `
- const { ethers } = require("hardhat");
+ y- U1 c- h9 F( d7 x9 t
- async function main() {
$ @ g3 X. G, |- e' ~1 j A
const initialSupply = ("100000000", 18); // 1亿枚,18位小数
: W8 U3 S5 p- ^. n' H" x6 t/ T
const token = await ("MyToken", [initialSupply]);
- ]5 p5 `/ t+ k! \2 h8 N
await ();
2 b* x' s! t/ ?5 w. Q p" K
("MyToken deployed to:", );
+ u; |- b8 l0 `% i) y! t6 x! l' n9 P
}
- s6 d% r$ I: \& v3 C' K% p
- main().catch((error) => {
! `0 ^6 d4 W+ O4 ^
(error);
( A: Z5 d$ p3 i* A( h
= 1;
3 Y$ Y4 K. N, Y' T, V! @ R% K
});
- R4 w$ f8 @7 U0 g- h6 M; V* \
六、编译与部署到测试网(Sepolia)
8 a, q/ H% A1 m M$ f% n! m, F
- 编译:npx hardhat compile
+ Y( m, o% s; o( ~! R( a
- 部署:npx hardhat run scripts/ --network sepolia
. H' P: ?% E4 v( o2 r8 D
- 运行成功会输出合约地址(MyToken deployed to: 0x...)
' S: j4 A2 p% k# z& p) y @
- 在区块浏览器()查询该地址,确认合约已上链
( d" e5 T( g( t7 E' I( U Q7 U( [
七、可选:合约源码校验(便于他人查看源码与构造参数)
2 d& H4 I- H M
- 命令:npx hardhat verify --network sepolia 合约地址 初始发行量(Wei)
9 e3 h' n$ L7 p$ E7 s3 N3 W' @' Y
- 例:npx hardhat verify --network sepolia 0xYourTokenAddress
_% p, a0 [0 t& C# _6 r/ S
100000000000000000000000000
v6 \2 `' a; ]; X% n! m# K
- 注意:这里的初始发行量需与部署脚本中的 initialSupply 完全一致(单位为 Wei)
$ o% Q$ T7 b0 P2 T# y
八、在钱包中查看代币
. |: A( o. n$ @- |5 V$ S# [
- 打开 MetaMask,选择对应网络(Sepolia 或主网)
9 l3 Z& n8 A+ i+ ]6 d
- 选择“导入代币”,粘贴合约地址,确认代币符号与小数位(18)
) i, K7 i" z4 H' u% _6 y
- 即可在钱包中看到初始发行的代币余额(在部署账户下)
: K) K, o2 U$ y; U; n+ J. h! G1 w
九、部署到主网(可选)
8 Y \3 \9 O' M, i: M( O
- 确保 .env 中配置 MAINNET_RPC_URL、PRIVATE_KEY,且钱包内有主网 ETH
& c( V/ D1 O# f7 w: |, G% H- P) d
- 命令:npx hardhat run scripts/ --network mainnet
; n# ]8 Y; ^4 A1 y {
- 可用 Etherscan 校验:npx hardhat verify --network mainnet 合约地址 初始发行量(Wei)
7 v3 v) s9 v# A% z% i
十、常见问题与排查
1 h5 n7 w4 X+ B5 g* O' N
- 部署报“insufficient funds for gas”:
. I3 g7 S" m1 P6 \0 S6 n% ]
- 账户没有足够 ETH(测试网/主网),先充值再部署
8 v9 Q9 s& d# n+ W; i/ E
- Ethers 版本导致的方法差异:
. |' ^5 c5 W `5 \+ m( X- A0 e: N* n
- 本教程基于 ethers v6(Hardhat Toolbox 默认),使用
5 V# M9 g9 w; W
- 私钥与 .env:
( E* Q8 [. f# _- L$ M; B2 ~
- PRIVATE_KEY 必须以 0x 开头,无引号与空格
5 c" T% t) i. b+ P' M
- 确保 .gitignore 排除 .env,切勿泄露私钥
8 p4 n0 }/ a/ P& [! r
- 构造参数不一致导致校验失败:
0 Q- }, Y+ K5 H
- verify 命令的初始发行量(Wei)必须与部署时完全一致
: J Q" }5 U. c% h C% ?
到这里,你已经完成了一个标准 ERC‑20 代币从“编写 → 编译 → 部署 →(可选)校验 → 钱包查看”的完整最小流程。若你需要把名称/符号/小数位做成可配置,或加入可增发/销毁、暂停等扩展权限。
# c! ]$ O# T" z+ B' F4 Y* B1 s5 A
下面是一键发币的工具;
+ i& e: p* ^1 Y+ d8 N& |
这个星辰发币是目前最好用的一个一键发币的工具( ),不需要授权,代码干净;最推荐。
% u: `2 k \ @7 \) O
这个dajgh也还可以但是需要授权( ),授权会带来一些安全方面的风险。
+ b2 }" T7 a: r. B7 m5 M7 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.cc/)
Powered by Discuz! X3.1