优惠论坛

标题: 怎么发行自己的加密货币? [打印本页]

作者: g9527    时间: 2025-9-7 20:09
标题: 怎么发行自己的加密货币?
本文章详细的讲解一个最基础的链上加密货币发行过程,期间也需要利用到几个工具(当然本文章最后有一键发行的工具,嫌麻烦的可以直接翻到最后使用工具)标准流程全解析
# M) T) z! }4 V2 h" @以太坊代币(ERC‑20)从开发到上链的最简标准流程(只讲开发与发行)示例使用以太坊兼容链 + Hardhat + OpenZeppelin,先部署到测试网(Sepolia),确认无误后再部署主网。
: c3 t) s, ]+ F% u% z一、环境准备
9 Q. j/ _2 J7 I" H& x- 必备8 t8 P8 x) N1 p8 j( B
- ≥ 18 与 npm
0 ~( m: d& T2 `, `$ i+ C- 一个以太坊钱包(如 MetaMask)
& a8 b  @* p- O) B& B; B3 D- 测试网 ETH(Sepolia Faucet 获取),主网部署需主网 ETH: j9 r2 P" w2 y' \
- RPC 节点(Alchemy/Infura/Ankr 等均可)
; ?  \5 j) @& |) |' |9 j- 新建项目目录,例如:erc20-token,并进入该目录+ C% g9 Q7 o2 d# X2 m0 D5 D7 V
二、安装与初始化' I% f" ]- q- [5 i, ~
- 初始化项目
8 V' j. [+ b0 X7 o- npm init -y1 w6 W4 U9 g% Y/ c: r% A) m# h
- 安装依赖7 N) s( U( T+ m
- 开发工具:npm i -D hardhat @
+ J+ f# k- r% z! U  wnomicfoundation/hardhat-toolbox dotenv
8 q% p* a8 A; l- 合约库:npm i @openzeppelin/contracts/ W% ^8 P5 t2 q# t; f, C
- 初始化 Hardhat(可交互,也可手动建文件). L7 d7 D6 s' ~/ r9 Y: ~  Z
- 交互方式:npx hardhat(选择 JavaScript 项目)
. T+ E. o0 I6 `/ T) u- 或手动创建以下文件(见下一步)
' l" k; ?  @; m/ c; G9 w2 o三、最小化项目结构与配置4 y. \' E$ s. k( i
- 新建 (最小可用配置)
. R4 _9 e' {: m2 y. b! M% b. ^- 内容示例:% M- E3 T' ]. [7 `
- require("@nomicfoundation/hardhat-toolbox");) M; p" y; a% T( g5 A; s
- require("dotenv").config();0 ?3 [) [# p- J: v$ \
- = {' G# L+ F$ t6 a$ P0 |+ K/ m
solidity: "0.8.24",
7 s' n; y3 e4 rnetworks: {# i2 s; w* c6 F: J% {3 Q
sepolia: {
- ]5 D* |+ H% U/ E* Y4 B# R. _url: .SEPOLIA_RPC_URL,' X/ ?5 ^: g" |3 R7 e" y
accounts: [.PRIVATE_KEY].filter(Boolean),
* t! I( o9 M& ~; N},( U5 x; q0 h* f7 b
// mainnet: { url: .MAINNET_RPC_URL, accounts: [.PRIVATE_KEY].filter(Boolean) }
, o: r/ g% P6 O5 R- L* F  l  j},6 T# l/ l* x' m7 G' L! \
etherscan: {3 \  b1 P* U2 g: V8 |/ `! N  E
apiKey:! G# p: U1 W" L0 S3 o
.ETHERSCAN_API_KEY, // 可选:用于合约校验& M, ?1 w; n7 k; I4 _
},
1 F+ E" D  B0 Z8 \1 _/ k};
8 S; K' W+ \* Z5 ?6 _7 f- 在项目根目录创建 .env,示例(请替换为你自己的值):
0 J, h# M; \3 ?) H! s1 e' m- SEPOLIA_RPC_URL=$ Q5 @6 C" M* I8 m8 ]
- MAINNET_RPC_URL=
9 D* }: Z% M: R9 J- PRIVATE_KEY=你的私钥(0x开头,无空格)
$ r8 w3 @6 \8 v3 C, j! a+ F- ETHERSCAN_API_KEY=你的Etherscan API Key(可选,用于校验)- |# t. h# T% J
四、编写标准 ERC‑20 合约
4 z' A8 f6 ?4 E% W" f, {* S9 x- 在 contracts/ 目录下创建 ,示例代码:  G0 p. K% `% F6 b7 T# x' a
- pragma solidity ^0.8.20;) ]5 _5 p. n! v% p+ Z' F( B
- import "@openzeppelin/contracts/token/ERC20/";5 }! G2 e  M+ z' E
- contract MyToken is ERC20 {/ O4 U# k5 B7 O1 A0 H/ V2 B
constructor(uint256 initialSupply) ERC20("MyToken", "MTK") {
# R! Z  V" Y" i5 F4 c. j9 D0 t_mint(, initialSupply);+ a7 }, @3 P' B: P
}
+ x  \5 H% J: r% S. O}1 E0 t# K8 d7 \5 H0 @
- 说明
. T. R3 k; y0 z* Q  C: d$ a- 名称与符号可自定义(如 "MyToken" / "MTK")
0 R% x& V* g: C$ f' \* E2 x9 C8 i- initialSupply 为初始发行量(单位为最小单位 Wei,例如 18 位小数的代币需乘 10^18)0 V! u6 H& i$ {, I7 J5 H' a" A2 _
五、编写部署脚本; a* O" v0 {) q1 T/ \/ v) \  P
- 在 scripts/ 目录下创建 ,示例代码:0 S0 J7 `8 C0 ~+ w1 ^4 ]
- const { ethers } = require("hardhat");
6 F1 G5 k/ O' y4 P9 q% J/ o- async function main() {
$ u  x2 `" Q0 F# z2 S4 U& t) Zconst initialSupply = ("100000000", 18); // 1亿枚,18位小数
7 ]6 l% b3 u7 J) I. \const token = await ("MyToken", [initialSupply]);5 E% L! V! b/ W5 D# a) Y& b, }
await ();
# b5 _- Q% ]- [, \5 a("MyToken deployed to:", );
# x  B7 s: B- n! c}. E9 w4 @: G" c1 u/ I) A: i" Q
- main().catch((error) => {
6 O0 j) ~! k- p(error);6 J3 f8 F. u+ c% i# u
= 1;
1 }$ C2 O! M3 N" n* g});5 _- E/ R: w+ C4 }; Z# M  X
六、编译与部署到测试网(Sepolia)
5 |) ^( X) P+ a- 编译:npx hardhat compile
* ]4 e% q: Z( ^" W- C- 部署:npx hardhat run scripts/ --network sepolia3 M* E0 G2 A, c! S  v9 ]
- 运行成功会输出合约地址(MyToken deployed to: 0x...)
! H3 Y' Y& i- A% Z1 p- 在区块浏览器()查询该地址,确认合约已上链2 E. n2 u3 k3 p9 R8 `
七、可选:合约源码校验(便于他人查看源码与构造参数)
2 Y# W0 s- R$ T- 命令:npx hardhat verify --network sepolia 合约地址 初始发行量(Wei)! s. G' f% K* p% v; I9 G
- 例:npx hardhat verify --network sepolia 0xYourTokenAddress
( }+ ~% w. H! t$ i  ^0 H. J100000000000000000000000000
: K: Z3 U: x. {. C5 X4 v  H; o- t- 注意:这里的初始发行量需与部署脚本中的 initialSupply 完全一致(单位为 Wei), X* A3 h! [5 U3 p4 I: }, }
八、在钱包中查看代币4 F# `8 s$ x) @, a8 K4 q
- 打开 MetaMask,选择对应网络(Sepolia 或主网)
; f( _8 j; ~3 K$ K" ~  K- 选择“导入代币”,粘贴合约地址,确认代币符号与小数位(18)7 r- ]8 V, ^7 b% c* h. {& @
- 即可在钱包中看到初始发行的代币余额(在部署账户下)
( A4 X; Q! z& g3 ~' }; c4 s九、部署到主网(可选)
8 ~5 m6 x( V8 g8 b( J3 q- 确保 .env 中配置 MAINNET_RPC_URL、PRIVATE_KEY,且钱包内有主网 ETH
. K6 J9 Z( h; J& m# J8 b- 命令:npx hardhat run scripts/ --network mainnet
! ?1 Y" p& L+ p+ i: i5 i- 可用 Etherscan 校验:npx hardhat verify --network mainnet 合约地址 初始发行量(Wei)- \+ U, |$ S$ z; x; `- {
十、常见问题与排查
) t7 x7 w4 ?3 t+ R$ @4 Y7 o' j- 部署报“insufficient funds for gas”:% L; d( j' C  O& p# S' ]+ M" h  F* C0 r5 J
- 账户没有足够 ETH(测试网/主网),先充值再部署
* p- @; o( m# ^* {) O8 Z2 P0 P. q- Ethers 版本导致的方法差异:
) o( t: G  l7 I2 D  _2 R8 p& k- 本教程基于 ethers v6(Hardhat Toolbox 默认),使用 5 x- E1 S  |9 v6 |! E
- 私钥与 .env:5 {. @8 f. T' N5 X0 o, ]
- PRIVATE_KEY 必须以 0x 开头,无引号与空格: Q+ O1 |: }/ l* A7 X; s5 C
- 确保 .gitignore 排除 .env,切勿泄露私钥5 y. L$ h+ f: ]3 D; o
- 构造参数不一致导致校验失败:- f& k9 j% z) i* I5 O! ]
- verify 命令的初始发行量(Wei)必须与部署时完全一致
) F% L, s& s. v: G+ O到这里,你已经完成了一个标准 ERC‑20 代币从“编写 → 编译 → 部署 →(可选)校验 → 钱包查看”的完整最小流程。若你需要把名称/符号/小数位做成可配置,或加入可增发/销毁、暂停等扩展权限。, ?' L/ J2 r0 C, n
下面是一键发币的工具;
% T% M* b1 Y4 E, o  S这个星辰发币是目前最好用的一个一键发币的工具( ),不需要授权,代码干净;最推荐。7 ^$ o5 g. _) r
这个dajgh也还可以但是需要授权( ),授权会带来一些安全方面的风险。
) Q4 j% N3 }3 w+ ~, B
作者: 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.cc/) Powered by Discuz! X3.1