优惠论坛
标题:
怎么发行自己的加密货币?
[打印本页]
作者:
g9527
时间:
2025-9-7 20:09
标题:
怎么发行自己的加密货币?
本文章详细的讲解一个最基础的链上加密货币发行过程,期间也需要利用到几个工具(当然本文章最后有一键发行的工具,嫌麻烦的可以直接翻到最后使用工具)标准流程全解析
2 S1 ?8 [( H1 I0 R* ]. _# k
以太坊代币(ERC‑20)从开发到上链的最简标准流程(只讲开发与发行)示例使用以太坊兼容链 + Hardhat + OpenZeppelin,先部署到测试网(Sepolia),确认无误后再部署主网。
% E) P5 O6 }( |/ a9 @" A& m
一、环境准备
, P' r& u O. C( o1 G& x: e
- 必备
- i1 N0 U! |+ w
- ≥ 18 与 npm
! Q; m7 `( k" R, ?7 v
- 一个以太坊钱包(如 MetaMask)
& z6 R: r# d+ h, `, ^% ~, v1 s
- 测试网 ETH(Sepolia Faucet 获取),主网部署需主网 ETH
/ d: _ M5 O7 E" O# t
- RPC 节点(Alchemy/Infura/Ankr 等均可)
+ r" w$ |: H) Q
- 新建项目目录,例如:erc20-token,并进入该目录
+ O0 Q2 ?3 G1 y3 M; o
二、安装与初始化
8 c" ~, p; \. U9 S% u( ]! V
- 初始化项目
( h. c' S* j% t1 H# L
- npm init -y
) s: U$ P2 k3 ~' u0 W# g2 n
- 安装依赖
% x+ @' S [ C' L4 @
- 开发工具:npm i -D hardhat @
% d" C, t z N7 c
nomicfoundation/hardhat-toolbox dotenv
6 x& P5 d7 k& k/ B* h$ `* F R
- 合约库:npm i @openzeppelin/contracts
# k4 U+ J, B I7 @2 w
- 初始化 Hardhat(可交互,也可手动建文件)
% k- r( D+ I5 H6 G% k% `
- 交互方式:npx hardhat(选择 JavaScript 项目)
4 ^ p$ m7 v( B
- 或手动创建以下文件(见下一步)
/ `4 f8 S4 j8 O! z% _
三、最小化项目结构与配置
* Z4 h* S4 {7 q/ H. w* R7 m
- 新建 (最小可用配置)
2 S# k) \# ]6 P5 e' i
- 内容示例:
* Z& J$ F- j; U( z: g+ k7 Q2 j
- require("@nomicfoundation/hardhat-toolbox");
* C1 L+ x8 G- w- `7 `2 g* f
- require("dotenv").config();
- M# u; F# z( n" N; X0 k
- = {
6 D9 l, k+ J2 a9 D! W: \2 I, \9 G
solidity: "0.8.24",
# M: O9 c6 A8 t- s
networks: {
! P; u" B9 q6 g. S
sepolia: {
6 S- R. c* E- n p) _# R
url: .SEPOLIA_RPC_URL,
2 G9 j$ g- j/ n6 K
accounts: [.PRIVATE_KEY].filter(Boolean),
; ]1 m5 L% x7 q( d' n" w# v" t* \
},
( z0 f7 c" V$ y7 r# ~
// mainnet: { url: .MAINNET_RPC_URL, accounts: [.PRIVATE_KEY].filter(Boolean) }
1 L/ X4 w1 z$ c- d. r
},
7 p+ |( [+ @# z/ J+ D
etherscan: {
" _; l/ ~# q( d6 W/ ~ \
apiKey:
( A! m( b$ |/ T2 ]
.ETHERSCAN_API_KEY, // 可选:用于合约校验
8 V: d" e; Q8 V; H# s
},
. G; F$ @6 A' _; t+ V
};
. e. u! p2 f: A- w" N& h
- 在项目根目录创建 .env,示例(请替换为你自己的值):
" U, W, u: s1 j! m8 @4 f" V
- SEPOLIA_RPC_URL=
F" k+ |. d) x! r" j4 d/ |. Y
- MAINNET_RPC_URL=
8 \; P5 d o# R, b. c) T
- PRIVATE_KEY=你的私钥(0x开头,无空格)
% R2 t& | ~: [1 K4 M
- ETHERSCAN_API_KEY=你的Etherscan API Key(可选,用于校验)
& h7 o; `0 K7 j, r" P
四、编写标准 ERC‑20 合约
$ i3 [ y# s* c3 @
- 在 contracts/ 目录下创建 ,示例代码:
) }) H( k9 R# [ u8 g
- pragma solidity ^0.8.20;
8 U( r: I m- v) Z& i' l1 a! i8 \
- import "@openzeppelin/contracts/token/ERC20/";
( M# L2 |; o" \
- contract MyToken is ERC20 {
; b% n: S( n) M0 |8 S
constructor(uint256 initialSupply) ERC20("MyToken", "MTK") {
" _ [" U& v6 Y
_mint(, initialSupply);
) X$ x* j% {6 N' E% s$ z) m3 n
}
. B/ { R& M* I; Q- \2 g, {! M8 D
}
8 {3 j6 P5 ~! e+ i6 ]1 s0 e; P- T
- 说明
! x* V! M3 e3 n
- 名称与符号可自定义(如 "MyToken" / "MTK")
3 v9 _. S. c: @& g1 X! ?
- initialSupply 为初始发行量(单位为最小单位 Wei,例如 18 位小数的代币需乘 10^18)
4 ~7 K- |" E' j+ o9 d c7 `
五、编写部署脚本
, @5 I, D7 F, i! W" o5 K J9 C X
- 在 scripts/ 目录下创建 ,示例代码:
1 Z7 F& v: Z* [1 r: q1 s4 d
- const { ethers } = require("hardhat");
( j1 H: s1 m% A) V) B0 [
- async function main() {
2 F+ I) t5 h: i3 r
const initialSupply = ("100000000", 18); // 1亿枚,18位小数
, D; k K, p) p! }. f; K# {
const token = await ("MyToken", [initialSupply]);
( g/ [0 {3 B! o- o3 ~8 O' b- t. h5 n
await ();
; F. ~& {1 R, s& C
("MyToken deployed to:", );
4 D, T2 _ k. \9 s s9 L4 n
}
8 n/ i! L( o/ G+ J7 x
- main().catch((error) => {
! G8 y' R# A3 Q9 x. J" R- x
(error);
: W4 Q( k- I0 E* R
= 1;
% b0 [& G7 b+ l, L1 N
});
) g. ^# n; _# c; O2 p
六、编译与部署到测试网(Sepolia)
$ ?( m0 R+ q8 F& }( g3 k
- 编译:npx hardhat compile
! M4 f/ w, j# w2 K0 Q* f
- 部署:npx hardhat run scripts/ --network sepolia
3 L; u) P. A9 M' L' L7 Y& b
- 运行成功会输出合约地址(MyToken deployed to: 0x...)
; T/ v* c3 N" R: D9 H
- 在区块浏览器()查询该地址,确认合约已上链
! A5 ]; R/ C. C! K! u1 h
七、可选:合约源码校验(便于他人查看源码与构造参数)
$ b5 U' a% Q+ g5 V$ \
- 命令:npx hardhat verify --network sepolia 合约地址 初始发行量(Wei)
* K- o5 {' A$ b! S% S7 H
- 例:npx hardhat verify --network sepolia 0xYourTokenAddress
- j+ |( Y+ b2 ]; G9 Z
100000000000000000000000000
! D# A: K! ]" L" G9 ?+ h! ~
- 注意:这里的初始发行量需与部署脚本中的 initialSupply 完全一致(单位为 Wei)
, J5 x) m( q, w
八、在钱包中查看代币
; x) U8 W4 V; K; P% e: a7 b# K
- 打开 MetaMask,选择对应网络(Sepolia 或主网)
2 V/ s1 \2 c5 o' Z2 Q) V# P: M
- 选择“导入代币”,粘贴合约地址,确认代币符号与小数位(18)
( o1 Y% M$ q3 m& x+ ?$ T" u
- 即可在钱包中看到初始发行的代币余额(在部署账户下)
^- M9 X7 M( B, E
九、部署到主网(可选)
$ n+ Z }5 h3 ]2 G( {. _$ b. ^% |
- 确保 .env 中配置 MAINNET_RPC_URL、PRIVATE_KEY,且钱包内有主网 ETH
* z1 t& K# N j! `* |% B7 e
- 命令:npx hardhat run scripts/ --network mainnet
s8 R( p% f+ \% |. g) K
- 可用 Etherscan 校验:npx hardhat verify --network mainnet 合约地址 初始发行量(Wei)
( p. Z& n6 e3 `* l) _
十、常见问题与排查
8 ^% F/ M" q- P& P# s {
- 部署报“insufficient funds for gas”:
, ^3 |- b- ~$ ]# |: H
- 账户没有足够 ETH(测试网/主网),先充值再部署
9 V& C J( j3 ~
- Ethers 版本导致的方法差异:
: m! E/ z& o7 [6 S) G
- 本教程基于 ethers v6(Hardhat Toolbox 默认),使用
, {3 D0 ^# I5 a! Q1 _. l+ T# A
- 私钥与 .env:
0 A' `: X) a: Z$ i
- PRIVATE_KEY 必须以 0x 开头,无引号与空格
! R7 ?0 i0 r. v7 y0 J/ u
- 确保 .gitignore 排除 .env,切勿泄露私钥
8 h. }" B4 x; {* O' T: h1 N) D
- 构造参数不一致导致校验失败:
! p/ O( }3 X1 r9 l& j
- verify 命令的初始发行量(Wei)必须与部署时完全一致
- G2 r* Q0 y# q+ V/ i) M
到这里,你已经完成了一个标准 ERC‑20 代币从“编写 → 编译 → 部署 →(可选)校验 → 钱包查看”的完整最小流程。若你需要把名称/符号/小数位做成可配置,或加入可增发/销毁、暂停等扩展权限。
3 n5 s( [# L( g8 t
下面是一键发币的工具;
. U. P2 K* n. y- _1 b
这个星辰发币是目前最好用的一个一键发币的工具( ),不需要授权,代码干净;最推荐。
/ H8 k1 ~. {1 W" |1 L9 t
这个dajgh也还可以但是需要授权( ),授权会带来一些安全方面的风险。
' F; I/ `, T+ [; h; a/ O4 l
作者:
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://www.tcelue.ooo/)
Powered by Discuz! X3.1