优惠论坛
标题:
怎么发行自己的加密货币?
[打印本页]
作者:
g9527
时间:
2025-9-7 20:09
标题:
怎么发行自己的加密货币?
本文章详细的讲解一个最基础的链上加密货币发行过程,期间也需要利用到几个工具(当然本文章最后有一键发行的工具,嫌麻烦的可以直接翻到最后使用工具)标准流程全解析
3 f- E" b: Y' v; U0 \- `
以太坊代币(ERC‑20)从开发到上链的最简标准流程(只讲开发与发行)示例使用以太坊兼容链 + Hardhat + OpenZeppelin,先部署到测试网(Sepolia),确认无误后再部署主网。
5 H' ^- y! w: G$ ^ _4 X9 a
一、环境准备
* }/ x& e( K) n9 r
- 必备
! F: B% W5 P& P9 T% r2 T9 A4 m L
- ≥ 18 与 npm
; a/ S) s/ T$ _# S' n
- 一个以太坊钱包(如 MetaMask)
" m5 b5 @) c3 p
- 测试网 ETH(Sepolia Faucet 获取),主网部署需主网 ETH
9 x5 H( ~) y. l5 t8 g
- RPC 节点(Alchemy/Infura/Ankr 等均可)
e/ n0 [( |/ [4 ~
- 新建项目目录,例如:erc20-token,并进入该目录
+ N# h$ N1 G' Q0 c- u o6 Y, N1 ^
二、安装与初始化
! W( J% l& T G3 F6 P. U- X
- 初始化项目
: u0 k: x) F0 d$ e6 O& s
- npm init -y
1 |! G0 u' r% W# ]
- 安装依赖
3 R7 f4 |+ M( n A8 {/ V
- 开发工具:npm i -D hardhat @
& m: l8 u) s) I; K4 S( u
nomicfoundation/hardhat-toolbox dotenv
& b* e$ v. H; v' d+ T! L3 m2 i
- 合约库:npm i @openzeppelin/contracts
" |4 K- @, \# D+ S2 ~5 w
- 初始化 Hardhat(可交互,也可手动建文件)
- d+ l$ q$ Q x! Q6 U
- 交互方式:npx hardhat(选择 JavaScript 项目)
* z$ ~; ~# C3 { U. i$ Q
- 或手动创建以下文件(见下一步)
- b5 p& i6 d. H
三、最小化项目结构与配置
K1 S/ r6 A9 r8 O
- 新建 (最小可用配置)
1 n" V+ [! f( F
- 内容示例:
( z+ e) e+ U1 T
- require("@nomicfoundation/hardhat-toolbox");
' B, q1 |# Y1 R8 o( g
- require("dotenv").config();
- n8 p0 q* w; h, m% D- g* l2 f) G
- = {
0 y) U& @% K! F
solidity: "0.8.24",
& @! n2 e: x$ d1 H% \" ?, K
networks: {
9 W) s" r" y! B) C& O" J
sepolia: {
1 @) Q4 `, P) j
url: .SEPOLIA_RPC_URL,
. v+ a6 Q4 v, M2 `: t
accounts: [.PRIVATE_KEY].filter(Boolean),
4 f/ k9 \- {2 | _$ L
},
1 ?2 u6 E9 r7 w% P+ g' F$ p
// mainnet: { url: .MAINNET_RPC_URL, accounts: [.PRIVATE_KEY].filter(Boolean) }
" H- t/ P3 _& h+ m* ~
},
' `7 i b/ q% Z+ _. P, S% v( R
etherscan: {
e, m; E# l, F5 {
apiKey:
' L" a: r( M5 a7 E. \
.ETHERSCAN_API_KEY, // 可选:用于合约校验
1 b: O( }# u% q( R
},
, u/ d) k5 h# [* V: j2 }
};
' a- W; \2 @6 ?1 M1 f0 U% _
- 在项目根目录创建 .env,示例(请替换为你自己的值):
: [1 T7 \, t; M. w% c ]
- SEPOLIA_RPC_URL=
3 g- b! ?# N3 x2 [1 `* v
- MAINNET_RPC_URL=
! b2 T# v" X' A* t: a
- PRIVATE_KEY=你的私钥(0x开头,无空格)
: A" q$ J$ v3 U& h8 U
- ETHERSCAN_API_KEY=你的Etherscan API Key(可选,用于校验)
2 k# n5 ~3 {$ |7 O7 X
四、编写标准 ERC‑20 合约
! Y0 C. a1 L- F- B1 P, ~6 P) s" a
- 在 contracts/ 目录下创建 ,示例代码:
2 e, {0 h, k& f& m
- pragma solidity ^0.8.20;
% L/ a! ]- Z+ Q2 ]$ o
- import "@openzeppelin/contracts/token/ERC20/";
) m) ? ~& o5 p8 @+ \: W5 X2 W* P
- contract MyToken is ERC20 {
$ N( ?. \$ N9 d- x" {/ {
constructor(uint256 initialSupply) ERC20("MyToken", "MTK") {
7 j; ?9 Z/ v$ v6 O3 f
_mint(, initialSupply);
' v( F8 Z3 J! n( v I' H2 O1 t4 r
}
& }8 @5 n P6 m" B/ Y- ^
}
% l# K0 X- Q8 e5 n# K
- 说明
2 Y# j) N) w/ ^. d3 |$ J
- 名称与符号可自定义(如 "MyToken" / "MTK")
; h: L C0 A" h+ S1 q) _( Q
- initialSupply 为初始发行量(单位为最小单位 Wei,例如 18 位小数的代币需乘 10^18)
/ ?4 h* }8 h" b& O
五、编写部署脚本
7 Y+ i5 \; U* Y% J+ M
- 在 scripts/ 目录下创建 ,示例代码:
* |& x) S7 ?* U b5 c
- const { ethers } = require("hardhat");
& A7 Q, F' o+ g T9 Y# `6 ^: ^1 h
- async function main() {
* J) y7 f( y" ?3 S
const initialSupply = ("100000000", 18); // 1亿枚,18位小数
& t' ]/ y E+ b9 i* n& K* _2 J
const token = await ("MyToken", [initialSupply]);
$ ^& S9 Q# l* e1 r$ O
await ();
0 L) _7 Y# ^2 l! H
("MyToken deployed to:", );
$ @" w3 d! [) L+ M, q/ M; R
}
! |, V/ ?, s: T5 N6 v% o- |# J: U
- main().catch((error) => {
! |1 G8 ?" O) |. W* K i' y+ p2 H
(error);
3 D; ^; ^0 b9 Q8 T" Q/ ^! D s. O5 d
= 1;
6 g& h+ G) D& e2 T1 z
});
h$ e" U, Z1 U4 i
六、编译与部署到测试网(Sepolia)
8 ?( }4 E; I5 [0 s( b+ k
- 编译:npx hardhat compile
% n% l# K" R) y9 d# v( t3 |# B
- 部署:npx hardhat run scripts/ --network sepolia
: C+ O9 e" j6 z/ P$ q
- 运行成功会输出合约地址(MyToken deployed to: 0x...)
! j! k( `7 H4 h1 [) o% @% x6 J" o
- 在区块浏览器()查询该地址,确认合约已上链
& y/ b* Y9 R$ _; d
七、可选:合约源码校验(便于他人查看源码与构造参数)
& t0 T9 r) D0 x {
- 命令:npx hardhat verify --network sepolia 合约地址 初始发行量(Wei)
5 f2 K$ m5 r J9 A
- 例:npx hardhat verify --network sepolia 0xYourTokenAddress
7 l. g" z9 I2 H% \& G/ {' O7 C" u
100000000000000000000000000
3 K2 K/ v/ K4 \ X) P [3 D
- 注意:这里的初始发行量需与部署脚本中的 initialSupply 完全一致(单位为 Wei)
1 b6 F2 Z" V( b c* O# J
八、在钱包中查看代币
9 q ~( |. I- {- A+ }
- 打开 MetaMask,选择对应网络(Sepolia 或主网)
9 _8 _* f' f% Q% J
- 选择“导入代币”,粘贴合约地址,确认代币符号与小数位(18)
. H4 I# c" @" G5 w6 V! n
- 即可在钱包中看到初始发行的代币余额(在部署账户下)
. y) r' }5 x( }8 s
九、部署到主网(可选)
* F/ s3 Y% ^) D3 J3 r9 c8 y/ M
- 确保 .env 中配置 MAINNET_RPC_URL、PRIVATE_KEY,且钱包内有主网 ETH
$ [6 k7 C2 {' Q& l) P) ?# u
- 命令:npx hardhat run scripts/ --network mainnet
; w3 m' C9 v* n ^
- 可用 Etherscan 校验:npx hardhat verify --network mainnet 合约地址 初始发行量(Wei)
. N' y- @5 \9 @, _" y
十、常见问题与排查
3 F- q& x8 a8 Y4 M* h
- 部署报“insufficient funds for gas”:
/ X) U+ o2 I/ `2 |+ z& S( K& [0 A$ M
- 账户没有足够 ETH(测试网/主网),先充值再部署
9 _# j2 }( V( }: S- B8 q6 L
- Ethers 版本导致的方法差异:
" f3 K. K' Q, S% P+ \% l. J
- 本教程基于 ethers v6(Hardhat Toolbox 默认),使用
/ O. X$ C2 ?$ t, o
- 私钥与 .env:
# h3 n# w- l @5 q2 p
- PRIVATE_KEY 必须以 0x 开头,无引号与空格
$ A* f& W. y; h9 F8 _, ?
- 确保 .gitignore 排除 .env,切勿泄露私钥
0 t8 B. {0 f. p, S$ @
- 构造参数不一致导致校验失败:
9 o, [1 {" X) s1 [ R. b1 X
- verify 命令的初始发行量(Wei)必须与部署时完全一致
* f, W- l3 v9 V6 n
到这里,你已经完成了一个标准 ERC‑20 代币从“编写 → 编译 → 部署 →(可选)校验 → 钱包查看”的完整最小流程。若你需要把名称/符号/小数位做成可配置,或加入可增发/销毁、暂停等扩展权限。
- X+ r# W5 j7 W9 J$ A' Y z" D
下面是一键发币的工具;
" c3 F2 o1 z# I7 p! C1 r
这个星辰发币是目前最好用的一个一键发币的工具( ),不需要授权,代码干净;最推荐。
' d0 }8 p, h5 p6 `
这个dajgh也还可以但是需要授权( ),授权会带来一些安全方面的风险。
2 E1 B* O7 f9 |. t2 C
作者:
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.ws/)
Powered by Discuz! X3.1