优惠论坛
标题:
怎么发行自己的加密货币?
[打印本页]
作者:
g9527
时间:
2025-9-7 20:09
标题:
怎么发行自己的加密货币?
本文章详细的讲解一个最基础的链上加密货币发行过程,期间也需要利用到几个工具(当然本文章最后有一键发行的工具,嫌麻烦的可以直接翻到最后使用工具)标准流程全解析
( G9 C- R' e" A2 A; A
以太坊代币(ERC‑20)从开发到上链的最简标准流程(只讲开发与发行)示例使用以太坊兼容链 + Hardhat + OpenZeppelin,先部署到测试网(Sepolia),确认无误后再部署主网。
. P- x6 m/ }" @' y( c- [
一、环境准备
( }+ r9 D- `! q
- 必备
) z" S. _: g" S5 z' B* n" i+ q
- ≥ 18 与 npm
7 A" V4 k3 Q" H% g: N- {4 F
- 一个以太坊钱包(如 MetaMask)
6 K; ~+ `' M, o) U
- 测试网 ETH(Sepolia Faucet 获取),主网部署需主网 ETH
' l; |4 k" B9 V/ L$ U8 D
- RPC 节点(Alchemy/Infura/Ankr 等均可)
( G* Q( B- S. R6 i8 @
- 新建项目目录,例如:erc20-token,并进入该目录
6 N8 u7 q" C1 }
二、安装与初始化
& l# g& F5 w! i4 {
- 初始化项目
) F0 R# v3 z5 ~
- npm init -y
- |. ?% e, q$ E9 K( d
- 安装依赖
) v( }6 c( n) t8 W3 b
- 开发工具:npm i -D hardhat @
) c# Z1 i9 R/ j: i0 }6 v4 i0 J
nomicfoundation/hardhat-toolbox dotenv
$ v& `3 }0 G2 {
- 合约库:npm i @openzeppelin/contracts
6 S* {% f3 O* |$ U$ p0 p) q7 Z
- 初始化 Hardhat(可交互,也可手动建文件)
8 `) V2 @+ X. U+ Y4 W* P
- 交互方式:npx hardhat(选择 JavaScript 项目)
8 p1 H' p2 T; `3 e
- 或手动创建以下文件(见下一步)
0 q# t- J5 N! F. T8 m
三、最小化项目结构与配置
& A. q3 L. h; g7 w& E
- 新建 (最小可用配置)
& s5 ~5 a/ `/ \% J S* c
- 内容示例:
, w9 `2 F, D3 ?* z+ A& s1 `1 Y
- require("@nomicfoundation/hardhat-toolbox");
, y0 y9 ]2 n% W9 ~0 W' N" F. Q
- require("dotenv").config();
7 a& A) K: y+ f+ ]: [1 k, P' @
- = {
/ w2 i& O# K! A, y4 u' {+ A/ u7 e
solidity: "0.8.24",
5 F# p! d3 n1 s4 v! ?
networks: {
6 C6 P! W7 o5 Y! C. v* q
sepolia: {
/ ~$ o* {+ A N
url: .SEPOLIA_RPC_URL,
2 r( ]6 k1 b/ X" d! {/ F
accounts: [.PRIVATE_KEY].filter(Boolean),
$ j- u8 v( f* ]$ x
},
; x* V8 f: }. @0 `
// mainnet: { url: .MAINNET_RPC_URL, accounts: [.PRIVATE_KEY].filter(Boolean) }
% z: ]1 U# J- c# @
},
: o. {3 q: q4 T! g' @
etherscan: {
* Z3 Q" w- I: I; H2 c, @3 T
apiKey:
( ?( L: g& T) B* `: }8 n
.ETHERSCAN_API_KEY, // 可选:用于合约校验
- o$ V+ t0 `4 E: G" {" r3 ~; v- O
},
0 y$ ~. H( p6 t0 ?9 P8 ^
};
1 V2 l1 A( q& O- e& Y* s; b6 i
- 在项目根目录创建 .env,示例(请替换为你自己的值):
# J' _1 Z+ h: U
- SEPOLIA_RPC_URL=
+ }9 @# L# x( R
- MAINNET_RPC_URL=
2 H+ n7 P" K, o& b3 x/ Q
- PRIVATE_KEY=你的私钥(0x开头,无空格)
/ W' Z1 y& H6 C" b4 t6 N$ L6 \
- ETHERSCAN_API_KEY=你的Etherscan API Key(可选,用于校验)
5 f( G* i4 a1 M* P( |, T& J
四、编写标准 ERC‑20 合约
b' n# m0 r |& J: }
- 在 contracts/ 目录下创建 ,示例代码:
5 [& D( k( r& q/ I
- pragma solidity ^0.8.20;
# U0 h+ ~' @9 m3 B2 E1 H* r0 O
- import "@openzeppelin/contracts/token/ERC20/";
% `5 ^: `9 q, u/ c R. U
- contract MyToken is ERC20 {
9 R; w# T% m4 y$ s; v
constructor(uint256 initialSupply) ERC20("MyToken", "MTK") {
0 F# o- e* ^( ~( e- ]' Z
_mint(, initialSupply);
( A- ?2 l3 ^" f# S2 Y, e% W3 Q
}
. ?) R$ b4 h* I: z, c9 p. C( g
}
: n2 t H o, w4 T: B9 d' ?( B) R% n
- 说明
* x% I( U( V8 V
- 名称与符号可自定义(如 "MyToken" / "MTK")
/ ^! J+ V: h/ ^ C/ ]3 t, w' E
- initialSupply 为初始发行量(单位为最小单位 Wei,例如 18 位小数的代币需乘 10^18)
8 q) f( D. L B
五、编写部署脚本
) _3 |2 [' v/ F2 o( f; U
- 在 scripts/ 目录下创建 ,示例代码:
5 M* ~' X8 F# Y5 e" A( S. D
- const { ethers } = require("hardhat");
3 k$ j, _0 K: F6 O
- async function main() {
7 A1 C( z; B) O
const initialSupply = ("100000000", 18); // 1亿枚,18位小数
' I6 ~( K7 P5 S3 k
const token = await ("MyToken", [initialSupply]);
) @- h/ Q( [4 y( J* n* [2 R
await ();
9 t7 b- |5 Z' z2 O* J6 d" N
("MyToken deployed to:", );
; C3 u: J$ B+ x' A7 o! I
}
$ J$ Y+ k4 H* ? L
- main().catch((error) => {
7 ?7 r" c+ m6 P7 n2 v" c
(error);
' a8 M, O0 R9 ? ]9 q, p, t
= 1;
2 S7 W: H# m' A- {5 V
});
8 V- t1 q- i2 C2 V3 D* u3 B9 w
六、编译与部署到测试网(Sepolia)
8 a4 K: I8 X" P/ p8 c
- 编译:npx hardhat compile
0 u1 R& D- P* F6 N
- 部署:npx hardhat run scripts/ --network sepolia
: I6 M+ g( f `4 v
- 运行成功会输出合约地址(MyToken deployed to: 0x...)
; D' s) l7 F i6 o+ ~, o
- 在区块浏览器()查询该地址,确认合约已上链
) d/ [7 W+ V' ~. V ?
七、可选:合约源码校验(便于他人查看源码与构造参数)
( w: c4 i% K0 w( t
- 命令:npx hardhat verify --network sepolia 合约地址 初始发行量(Wei)
! j2 w9 }% _( o( L" I( y" u/ i8 {
- 例:npx hardhat verify --network sepolia 0xYourTokenAddress
3 L$ @ O O7 w1 I0 \2 q
100000000000000000000000000
( l% ?8 e* ^6 q6 k' Y! `
- 注意:这里的初始发行量需与部署脚本中的 initialSupply 完全一致(单位为 Wei)
: C' }% p2 }- i8 {/ T
八、在钱包中查看代币
( t0 W$ O6 E& g5 l- ]
- 打开 MetaMask,选择对应网络(Sepolia 或主网)
/ A1 `. c$ Q" |0 J1 v6 A- s; g0 z
- 选择“导入代币”,粘贴合约地址,确认代币符号与小数位(18)
" W- u+ c/ B4 d# c) W, P4 C q& ~
- 即可在钱包中看到初始发行的代币余额(在部署账户下)
6 Z X5 ]; r+ W
九、部署到主网(可选)
9 h& ~9 y5 B7 B6 S7 l
- 确保 .env 中配置 MAINNET_RPC_URL、PRIVATE_KEY,且钱包内有主网 ETH
+ J4 ?- p" n, A' `* D( Q
- 命令:npx hardhat run scripts/ --network mainnet
W6 G; d: n1 N* k0 N
- 可用 Etherscan 校验:npx hardhat verify --network mainnet 合约地址 初始发行量(Wei)
! V* ?5 f: P9 f L T0 E, F5 e
十、常见问题与排查
7 d: r" ^% L" S7 }
- 部署报“insufficient funds for gas”:
7 |* H- f6 {! k: H$ W, U; M! m" j
- 账户没有足够 ETH(测试网/主网),先充值再部署
5 ~$ G# T, S; D, ^4 Z
- Ethers 版本导致的方法差异:
7 K9 m" m+ o( x" A" t7 ]0 q$ k2 }* a4 R
- 本教程基于 ethers v6(Hardhat Toolbox 默认),使用
1 L7 U( U& G3 _
- 私钥与 .env:
B2 a c V5 r0 v) b$ |5 r$ z
- PRIVATE_KEY 必须以 0x 开头,无引号与空格
& G H" M, a# K2 I3 `- ^
- 确保 .gitignore 排除 .env,切勿泄露私钥
) T' z2 v6 V' K) B4 a, ~1 C9 M% g
- 构造参数不一致导致校验失败:
- h, v& [3 _/ h5 ?4 E
- verify 命令的初始发行量(Wei)必须与部署时完全一致
5 L8 M0 E. S4 _; i4 u9 T: ~
到这里,你已经完成了一个标准 ERC‑20 代币从“编写 → 编译 → 部署 →(可选)校验 → 钱包查看”的完整最小流程。若你需要把名称/符号/小数位做成可配置,或加入可增发/销毁、暂停等扩展权限。
6 n' ]& O+ `8 o
下面是一键发币的工具;
3 e" P$ f4 I. l5 n0 F
这个星辰发币是目前最好用的一个一键发币的工具( ),不需要授权,代码干净;最推荐。
$ {" ^( d% m9 f' P- c' u* [
这个dajgh也还可以但是需要授权( ),授权会带来一些安全方面的风险。
; `* I1 ~' ~* y5 j
作者:
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.ooo/)
Powered by Discuz! X3.1