优惠论坛
标题:
怎么发行自己的加密货币?
[打印本页]
作者:
g9527
时间:
2025-9-7 20:09
标题:
怎么发行自己的加密货币?
本文章详细的讲解一个最基础的链上加密货币发行过程,期间也需要利用到几个工具(当然本文章最后有一键发行的工具,嫌麻烦的可以直接翻到最后使用工具)标准流程全解析
5 s0 E! A- R3 `$ h. U; g9 W; l
以太坊代币(ERC‑20)从开发到上链的最简标准流程(只讲开发与发行)示例使用以太坊兼容链 + Hardhat + OpenZeppelin,先部署到测试网(Sepolia),确认无误后再部署主网。
, t3 n! x& ^9 m% u$ n
一、环境准备
! q5 ] J: @0 g: g# d; d
- 必备
/ U# H3 I2 Q0 V. N% ?% ?
- ≥ 18 与 npm
9 C3 y/ Q4 `: g
- 一个以太坊钱包(如 MetaMask)
5 g0 Q1 `* a2 L: D
- 测试网 ETH(Sepolia Faucet 获取),主网部署需主网 ETH
+ A3 C! ]+ W! B% I
- RPC 节点(Alchemy/Infura/Ankr 等均可)
$ w ?! H1 ]" O# y8 Z1 p8 `, K
- 新建项目目录,例如:erc20-token,并进入该目录
7 ~, i# g9 Q% M/ }: @( Y
二、安装与初始化
- u# o; |! I% R9 u: ^
- 初始化项目
. Q# D. d4 F6 f B& F4 s
- npm init -y
- ?8 \% t$ Z) d, y
- 安装依赖
& ~% _- ?6 E0 {, R9 R
- 开发工具:npm i -D hardhat @
! }8 M! \- K4 k+ Q" @
nomicfoundation/hardhat-toolbox dotenv
. U- f2 ]% e# S* o- V1 Z9 b4 q
- 合约库:npm i @openzeppelin/contracts
2 W5 r" W/ ]. Z; {1 e: C; M
- 初始化 Hardhat(可交互,也可手动建文件)
! I/ h. R& X3 i* ^2 L% s
- 交互方式:npx hardhat(选择 JavaScript 项目)
; r% P1 S x$ d- Z4 I% a9 G$ |& i
- 或手动创建以下文件(见下一步)
2 v7 c8 ^% _ T: x1 O' c! p
三、最小化项目结构与配置
- k8 @9 f( b: D
- 新建 (最小可用配置)
; m# P' v6 M6 C
- 内容示例:
/ z8 h; c% v! r
- require("@nomicfoundation/hardhat-toolbox");
4 M2 v: G0 [- y
- require("dotenv").config();
$ V0 C2 z/ ^! W" k( \
- = {
# d* Z7 D7 g5 U! k
solidity: "0.8.24",
7 P8 {6 Y. @/ E/ d3 |) {4 S
networks: {
+ B( ]* C+ b& n9 H/ F
sepolia: {
: s* X9 V, ^; }5 A, S2 {' J
url: .SEPOLIA_RPC_URL,
8 r1 p0 x$ q) {( I
accounts: [.PRIVATE_KEY].filter(Boolean),
8 x9 R0 h/ m) r6 ^$ E, t
},
( ^, |5 D, |( d: Z4 B& Z- v
// mainnet: { url: .MAINNET_RPC_URL, accounts: [.PRIVATE_KEY].filter(Boolean) }
: S2 I8 z" Y2 g7 L1 a
},
2 ^" i& v9 e+ P& l; P3 V
etherscan: {
; r2 f/ ^9 v) ^$ d5 x: U7 w* Z, f6 X
apiKey:
$ t- U0 Q$ r* X# @: j
.ETHERSCAN_API_KEY, // 可选:用于合约校验
" V$ X3 x* t2 x8 ]& X( g# Z# d. X- P
},
. v R+ R6 g' Q5 G
};
$ C2 u d$ r5 w0 L1 X8 u
- 在项目根目录创建 .env,示例(请替换为你自己的值):
4 y5 k7 ^7 F% n1 N, Y2 D& K
- SEPOLIA_RPC_URL=
+ H2 J% z: c+ [: t) G
- MAINNET_RPC_URL=
( Y% d/ J+ U4 A* \7 g
- PRIVATE_KEY=你的私钥(0x开头,无空格)
# j/ H K3 V* O
- ETHERSCAN_API_KEY=你的Etherscan API Key(可选,用于校验)
: m8 R ^/ G, `8 H! J1 m' b
四、编写标准 ERC‑20 合约
+ h) R; C' I& E
- 在 contracts/ 目录下创建 ,示例代码:
; [" U7 x4 `4 x+ F. x1 K8 O* i' t
- pragma solidity ^0.8.20;
, n) ]& s+ d$ m, c/ n
- import "@openzeppelin/contracts/token/ERC20/";
8 U2 R& w4 w( A% i/ d
- contract MyToken is ERC20 {
+ ?/ y: }5 |( ^6 P& h9 {
constructor(uint256 initialSupply) ERC20("MyToken", "MTK") {
" L4 X- G7 k7 X0 N* Z
_mint(, initialSupply);
8 u3 f, E' u8 C, k# J
}
7 Y0 l8 b$ K& T$ g. [8 o; \
}
* {% z$ u, ]+ k1 D
- 说明
2 _9 _- r0 u. X! s: @4 H( u3 N
- 名称与符号可自定义(如 "MyToken" / "MTK")
$ _! _* e% j/ X. w7 Q# y+ _ }; r
- initialSupply 为初始发行量(单位为最小单位 Wei,例如 18 位小数的代币需乘 10^18)
( W' v! B; g" Y
五、编写部署脚本
9 W2 z- S! i/ [4 Y$ r8 Q S* x
- 在 scripts/ 目录下创建 ,示例代码:
; b; m! Z5 J9 u
- const { ethers } = require("hardhat");
( {8 F- u& A! o
- async function main() {
5 Y) a9 F. ?3 _$ F: M6 c
const initialSupply = ("100000000", 18); // 1亿枚,18位小数
. M" \$ M0 y9 ]* f/ l. F
const token = await ("MyToken", [initialSupply]);
" K& Y. k5 u4 I/ |) Y
await ();
2 m# J7 Q& d, s& v2 s
("MyToken deployed to:", );
# C4 ~9 ^6 S* y7 w( V! U; c& K, Q" ~
}
4 B# I3 u0 a) `
- main().catch((error) => {
% u' A6 J2 m) C
(error);
3 X: [4 s/ b' h, e" b
= 1;
! ?% u7 N L4 b" E" B1 j! T
});
" ^/ s3 s8 ]% g3 P+ L
六、编译与部署到测试网(Sepolia)
# H/ P4 l7 U+ w4 `
- 编译:npx hardhat compile
# S& b$ \* z! N5 H, |
- 部署:npx hardhat run scripts/ --network sepolia
9 ?6 n) g3 H3 i: V! i( k. P3 S
- 运行成功会输出合约地址(MyToken deployed to: 0x...)
9 ^ D# O5 G% f* j+ b
- 在区块浏览器()查询该地址,确认合约已上链
& J9 p- g) U/ r( \* Y5 g0 {
七、可选:合约源码校验(便于他人查看源码与构造参数)
5 a6 s0 O1 {' n# V: ?; J* N( R
- 命令:npx hardhat verify --network sepolia 合约地址 初始发行量(Wei)
: W* Z; R; F$ h u1 V# Z
- 例:npx hardhat verify --network sepolia 0xYourTokenAddress
& w* d% b8 Y3 `0 y+ J/ X
100000000000000000000000000
! d, h+ m2 I) |3 X3 A) H* ~# Y
- 注意:这里的初始发行量需与部署脚本中的 initialSupply 完全一致(单位为 Wei)
) b( g4 |( v. J6 w& d0 u
八、在钱包中查看代币
# J, L2 h. B: U9 C1 {
- 打开 MetaMask,选择对应网络(Sepolia 或主网)
% V3 r) H# @, R
- 选择“导入代币”,粘贴合约地址,确认代币符号与小数位(18)
- p4 @9 c, [" R" T( a/ ?
- 即可在钱包中看到初始发行的代币余额(在部署账户下)
: f9 g# |5 e6 u8 x! c
九、部署到主网(可选)
' O& \# E3 P- U8 |7 V2 K
- 确保 .env 中配置 MAINNET_RPC_URL、PRIVATE_KEY,且钱包内有主网 ETH
7 f2 M. l7 a$ e0 e& S8 U1 D
- 命令:npx hardhat run scripts/ --network mainnet
, E, W- g0 H5 N5 |4 \4 `
- 可用 Etherscan 校验:npx hardhat verify --network mainnet 合约地址 初始发行量(Wei)
2 F- d" b. c5 ?8 ]0 ?! i
十、常见问题与排查
, Y4 ?+ Z% J$ Z9 V) M
- 部署报“insufficient funds for gas”:
3 h! h. f" T; a2 A7 _1 }9 K
- 账户没有足够 ETH(测试网/主网),先充值再部署
% j( ?( g4 H" p1 l
- Ethers 版本导致的方法差异:
! T/ q) d3 o) b! z# a
- 本教程基于 ethers v6(Hardhat Toolbox 默认),使用
# M4 V2 a$ P( o; Q" m0 U. o
- 私钥与 .env:
4 d3 u4 ?0 F u0 ?" F+ A+ J9 y
- PRIVATE_KEY 必须以 0x 开头,无引号与空格
( h( j; I( p- M7 x4 Y7 v2 ^' o# W: i
- 确保 .gitignore 排除 .env,切勿泄露私钥
! P& w4 C1 x2 }8 @
- 构造参数不一致导致校验失败:
) x" q7 q+ U. v( _. f' }3 d, V
- verify 命令的初始发行量(Wei)必须与部署时完全一致
6 @" l* \3 p" g6 |( [: C4 D
到这里,你已经完成了一个标准 ERC‑20 代币从“编写 → 编译 → 部署 →(可选)校验 → 钱包查看”的完整最小流程。若你需要把名称/符号/小数位做成可配置,或加入可增发/销毁、暂停等扩展权限。
Q0 z" E/ [, F7 K# |' t
下面是一键发币的工具;
2 B. h4 T/ _% B5 t h6 Y# ^: M
这个星辰发币是目前最好用的一个一键发币的工具( ),不需要授权,代码干净;最推荐。
2 T E/ I2 m5 e! z7 H% m% T, K3 v
这个dajgh也还可以但是需要授权( ),授权会带来一些安全方面的风险。
" Z- w8 d% l9 C$ y6 J- z
作者:
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
这个需要有资格吧,个人是不可能的吧
作者:
爱美的女人
时间:
2025-9-10 21:36
这是不知道的啊,怎么会发行了
欢迎光临 优惠论坛 (https://tcelue.co/)
Powered by Discuz! X3.1