优惠论坛
标题:
怎么发行自己的加密货币?
[打印本页]
作者:
g9527
时间:
2025-9-7 20:09
标题:
怎么发行自己的加密货币?
本文章详细的讲解一个最基础的链上加密货币发行过程,期间也需要利用到几个工具(当然本文章最后有一键发行的工具,嫌麻烦的可以直接翻到最后使用工具)标准流程全解析
2 \4 F0 A L7 y" T
以太坊代币(ERC‑20)从开发到上链的最简标准流程(只讲开发与发行)示例使用以太坊兼容链 + Hardhat + OpenZeppelin,先部署到测试网(Sepolia),确认无误后再部署主网。
0 U( e' y/ v" `" ]: q. f
一、环境准备
3 E# Z* \' U. K3 I! Q
- 必备
`5 x" p4 \: U% `8 k
- ≥ 18 与 npm
1 W( G* ~. Z3 }; J$ x& ~
- 一个以太坊钱包(如 MetaMask)
, Y8 M K { ~1 O9 Y" \3 ?
- 测试网 ETH(Sepolia Faucet 获取),主网部署需主网 ETH
; i+ D. H' }3 ~+ A
- RPC 节点(Alchemy/Infura/Ankr 等均可)
- K. m. M7 t; Y% x& q+ R
- 新建项目目录,例如:erc20-token,并进入该目录
e( o7 i: E: z& ~! m
二、安装与初始化
! y$ U: W- B. W5 f4 w* H v
- 初始化项目
: G% z W# ~0 k& l, T7 d
- npm init -y
4 z" x( ?, m3 G- I
- 安装依赖
% X; i; A' G# j9 H$ y
- 开发工具:npm i -D hardhat @
0 R$ u7 _0 N2 ?. j" V* V- J0 N! V
nomicfoundation/hardhat-toolbox dotenv
( A+ p7 d/ A4 H. e- S
- 合约库:npm i @openzeppelin/contracts
! T0 \9 _! M2 q% r' m$ N6 d
- 初始化 Hardhat(可交互,也可手动建文件)
h/ ?2 ]* ]* X$ U- B" k! H1 G
- 交互方式:npx hardhat(选择 JavaScript 项目)
( n6 _6 A/ f \% c* u
- 或手动创建以下文件(见下一步)
9 T; b1 E& \9 j+ J( y: t, \4 ?4 M
三、最小化项目结构与配置
3 A: z# z V8 `; t7 o5 E2 r
- 新建 (最小可用配置)
0 r5 G% Y! m2 g& \2 N3 ?
- 内容示例:
0 L8 T* T6 f# `8 z5 x, A6 i
- require("@nomicfoundation/hardhat-toolbox");
% R/ M" M* W5 Y6 o6 u
- require("dotenv").config();
$ b' P: r! s: a2 O( j' B" v
- = {
( T7 z2 N H7 ?
solidity: "0.8.24",
7 y8 T! G; P' w. I# Q3 V
networks: {
0 u( a' H. g d3 S8 {
sepolia: {
6 {0 c, i% G% Y, w( Z/ y7 `& c
url: .SEPOLIA_RPC_URL,
5 o4 S q& q: G) t: y5 {7 N
accounts: [.PRIVATE_KEY].filter(Boolean),
; g' k ]" a' q, [3 H8 d, f6 L& K
},
" t( @" }- L6 w
// mainnet: { url: .MAINNET_RPC_URL, accounts: [.PRIVATE_KEY].filter(Boolean) }
( @) J' F: {& @& j. O/ h, q! _6 `
},
9 N& V" t& o/ d \7 p# X
etherscan: {
6 C3 [! ?" H1 R0 \* A7 P5 S
apiKey:
+ k p+ J+ ^" O6 U* C7 [0 H
.ETHERSCAN_API_KEY, // 可选:用于合约校验
( t% y* m$ [# v* k
},
: m0 C8 k8 {# b# P6 N* _ I, Z
};
/ a/ t; Y0 K( t
- 在项目根目录创建 .env,示例(请替换为你自己的值):
: V( O0 [# [1 j9 d
- SEPOLIA_RPC_URL=
* k: T: k! U1 |' O
- MAINNET_RPC_URL=
0 \9 h% e w5 m" A, H4 `
- PRIVATE_KEY=你的私钥(0x开头,无空格)
$ u! M, f/ O* D5 o# b- @
- ETHERSCAN_API_KEY=你的Etherscan API Key(可选,用于校验)
9 B/ L, ^8 j; I7 y
四、编写标准 ERC‑20 合约
' \5 _9 x, B, i+ h4 u: R
- 在 contracts/ 目录下创建 ,示例代码:
) }+ l5 ~: J0 R6 ?: P9 ]
- pragma solidity ^0.8.20;
) M( X4 r, j' u8 g2 N+ c+ W/ R& p2 D
- import "@openzeppelin/contracts/token/ERC20/";
- }; h- l& e" L. r
- contract MyToken is ERC20 {
/ S3 a9 ?3 s, q" S9 x+ t; L
constructor(uint256 initialSupply) ERC20("MyToken", "MTK") {
A @7 g& z0 P! l' T8 l
_mint(, initialSupply);
7 M' T& X6 `+ U
}
7 |' Q# I5 h! {" B; v
}
% o; r; B. S: [2 G5 G9 K
- 说明
5 B2 v, |' ?* [1 b
- 名称与符号可自定义(如 "MyToken" / "MTK")
! m F6 K; z8 s3 [! U
- initialSupply 为初始发行量(单位为最小单位 Wei,例如 18 位小数的代币需乘 10^18)
# v% [: A2 T6 f5 T. O- {+ L3 a
五、编写部署脚本
, i8 P/ a7 ]$ g1 S
- 在 scripts/ 目录下创建 ,示例代码:
: i* L& f5 s+ ^# n/ G: |: d
- const { ethers } = require("hardhat");
" I2 _2 U1 m2 @- t6 b
- async function main() {
/ Q& Y, [! v* U+ `7 }% R
const initialSupply = ("100000000", 18); // 1亿枚,18位小数
5 |, a4 d/ B1 N2 t3 Q' D7 w
const token = await ("MyToken", [initialSupply]);
3 S- U! y# ~8 q# {! D
await ();
& ]$ K1 S e; i) h
("MyToken deployed to:", );
~3 {) H( E+ r1 y( A" V
}
& z& n# u4 a; X5 N1 ^1 }0 _: C# F$ A
- main().catch((error) => {
, _/ ]/ J/ L6 r; X/ f$ \* \
(error);
5 y" X" F( R2 P7 Z& G- u. ~# [
= 1;
* @0 k$ }" J/ N. @) T, w
});
/ T" r8 D. \( ~" e6 @
六、编译与部署到测试网(Sepolia)
7 B% ~! c# [ J- z7 q: Q
- 编译:npx hardhat compile
# n& ?) M6 ~! D. M$ v0 Y% `" N! Q; _
- 部署:npx hardhat run scripts/ --network sepolia
! ?0 _0 ?! S5 Z: s
- 运行成功会输出合约地址(MyToken deployed to: 0x...)
5 Z6 R5 m# J/ _2 l& a
- 在区块浏览器()查询该地址,确认合约已上链
: t7 Y' M M6 q5 H& ^3 P5 W
七、可选:合约源码校验(便于他人查看源码与构造参数)
- C% c1 C/ Q% h
- 命令:npx hardhat verify --network sepolia 合约地址 初始发行量(Wei)
+ {, r, G7 ~* d7 l1 ]8 p( _+ m# O! t
- 例:npx hardhat verify --network sepolia 0xYourTokenAddress
2 z3 k' J$ e, k$ e* }; y
100000000000000000000000000
. ^& V% w8 X( v% @2 N! Q* E/ `+ Z9 T
- 注意:这里的初始发行量需与部署脚本中的 initialSupply 完全一致(单位为 Wei)
5 P( c1 C; N' R' O/ n( z! n
八、在钱包中查看代币
0 g2 l8 \# W6 h: r+ z
- 打开 MetaMask,选择对应网络(Sepolia 或主网)
( k: J! Z: M0 A
- 选择“导入代币”,粘贴合约地址,确认代币符号与小数位(18)
* @- o$ b6 m2 P- v
- 即可在钱包中看到初始发行的代币余额(在部署账户下)
) E. M2 ^4 B; L. Y: v. K {1 F3 `
九、部署到主网(可选)
& z T6 e5 q! n2 M( N
- 确保 .env 中配置 MAINNET_RPC_URL、PRIVATE_KEY,且钱包内有主网 ETH
9 T! S- g6 p3 M& V/ f
- 命令:npx hardhat run scripts/ --network mainnet
" @" P5 s& Z! d5 v: e4 @) ?
- 可用 Etherscan 校验:npx hardhat verify --network mainnet 合约地址 初始发行量(Wei)
7 v" J* E: G* ?6 l% |
十、常见问题与排查
8 r, |2 q3 c/ q/ j6 T4 n3 F6 R3 p
- 部署报“insufficient funds for gas”:
; X0 F m T& k1 g6 L, ~8 j
- 账户没有足够 ETH(测试网/主网),先充值再部署
5 M0 v8 u0 a8 R2 l
- Ethers 版本导致的方法差异:
& `/ P6 s! O G$ g$ b
- 本教程基于 ethers v6(Hardhat Toolbox 默认),使用
R/ r" s, V9 a2 ]' m7 W5 ?5 o
- 私钥与 .env:
1 z3 a% k4 @% u; j/ t/ P
- PRIVATE_KEY 必须以 0x 开头,无引号与空格
3 O3 U4 J# \" Y2 B, k: n& \5 ~) s
- 确保 .gitignore 排除 .env,切勿泄露私钥
4 O( v) ]$ Z" z3 Q
- 构造参数不一致导致校验失败:
+ X y$ a$ `& D2 R+ c1 T) Y- H- G( D
- verify 命令的初始发行量(Wei)必须与部署时完全一致
N. w# ?2 Y' _7 Y
到这里,你已经完成了一个标准 ERC‑20 代币从“编写 → 编译 → 部署 →(可选)校验 → 钱包查看”的完整最小流程。若你需要把名称/符号/小数位做成可配置,或加入可增发/销毁、暂停等扩展权限。
+ v+ @7 X: _0 G" Q6 Q
下面是一键发币的工具;
7 e# X( ^' u+ L4 b) W) @' t
这个星辰发币是目前最好用的一个一键发币的工具( ),不需要授权,代码干净;最推荐。
C5 q+ i" _) z% _" R- D; j
这个dajgh也还可以但是需要授权( ),授权会带来一些安全方面的风险。
9 a5 Y' l/ a; X; c( B. E
作者:
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://www.tcelue.ooo/)
Powered by Discuz! X3.1