优惠论坛

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

作者: g9527    时间: 2025-9-7 20:09
标题: 怎么发行自己的加密货币?
本文章详细的讲解一个最基础的链上加密货币发行过程,期间也需要利用到几个工具(当然本文章最后有一键发行的工具,嫌麻烦的可以直接翻到最后使用工具)标准流程全解析
7 V, r, [2 n6 [) l+ h5 r以太坊代币(ERC‑20)从开发到上链的最简标准流程(只讲开发与发行)示例使用以太坊兼容链 + Hardhat + OpenZeppelin,先部署到测试网(Sepolia),确认无误后再部署主网。
4 j2 P* d' M. Z  Y$ d$ S一、环境准备3 @* c$ |9 L! u9 z, w3 x1 Q/ m
- 必备
! v  y5 f% h% e- ≥ 18 与 npm
! c! C. M7 m" C: Q# H2 j5 f- 一个以太坊钱包(如 MetaMask)$ g( H% W. ]5 B. @; b* [' Z
- 测试网 ETH(Sepolia Faucet 获取),主网部署需主网 ETH
) W& H$ L# D9 S* b- RPC 节点(Alchemy/Infura/Ankr 等均可)
& U3 f. q, m% m- 新建项目目录,例如:erc20-token,并进入该目录
4 I  e4 d+ A6 E) H二、安装与初始化
0 A' n; Z, r. ?0 b- 初始化项目, K  R: y& [( g5 b( ^* P' @! T8 k: P
- npm init -y7 n. i3 B! H6 z8 \  X
- 安装依赖
# Z8 Z9 K* b& e( g+ y2 @4 T$ h- 开发工具:npm i -D hardhat @
# N- Y8 G$ t; H8 O0 W0 ]) {nomicfoundation/hardhat-toolbox dotenv
# P3 [, o" h; [$ J0 c. ^- O- 合约库:npm i @openzeppelin/contracts
' \4 F6 C. R; w* [- 初始化 Hardhat(可交互,也可手动建文件)
6 V# {$ E) ~7 T! H; v- 交互方式:npx hardhat(选择 JavaScript 项目)
: a7 u0 G3 \4 k+ X, J0 ^* x7 f* z- P- 或手动创建以下文件(见下一步)
! e- z' \3 I) R4 T7 k/ ?三、最小化项目结构与配置9 f9 }$ y9 f1 X) k- o
- 新建 (最小可用配置)
6 m+ `$ U# W, o. G0 e- 内容示例:
$ ~& D) J6 {7 p7 Q7 d- require("@nomicfoundation/hardhat-toolbox");
* M* \8 h0 V* O# u" b, p7 }- require("dotenv").config();
0 s+ r% C# ^  P: S  E* I4 f8 r$ q- = {
. Q/ U0 D5 l+ v9 c9 P: csolidity: "0.8.24",
, q0 ^8 {' v  w+ K% pnetworks: {* ~' L7 v1 r- A' K3 b
sepolia: {( M+ b% Q& i( ?0 C
url: .SEPOLIA_RPC_URL,  o6 m- |3 k6 n" g1 y
accounts: [.PRIVATE_KEY].filter(Boolean),
# t' ~) n4 c) o  v7 I6 `},
7 X9 m: i2 m. v/ O// mainnet: { url: .MAINNET_RPC_URL, accounts: [.PRIVATE_KEY].filter(Boolean) }
* N* D+ o6 |5 G9 a- l: G' R},# E: i& @1 O; x4 [* Z/ z+ G
etherscan: {
' Z2 Z" W- S$ z/ s, G+ j- |* xapiKey:
7 x, _8 f  P  P$ n.ETHERSCAN_API_KEY, // 可选:用于合约校验+ h/ Y4 P& V3 B' ?) P. e+ T; n
},! p3 F! |9 P- |3 X5 L* W
};
& I( P0 e$ M3 n* F- 在项目根目录创建 .env,示例(请替换为你自己的值):+ h+ @1 f. U+ Z$ e- u
- SEPOLIA_RPC_URL=4 A. F% N- [0 l, ]) h0 A5 p
- MAINNET_RPC_URL=4 ^% a. U# @) s( Q0 z$ p- p1 I5 ]
- PRIVATE_KEY=你的私钥(0x开头,无空格)
8 E: T, g- E8 Y0 D& O, g6 g) x4 m( R. `- ETHERSCAN_API_KEY=你的Etherscan API Key(可选,用于校验)/ E" R4 c* b, ^( W$ P: Z1 v
四、编写标准 ERC‑20 合约: i1 I7 ?7 F6 m  a8 V% `: O  }' X
- 在 contracts/ 目录下创建 ,示例代码:
) B6 X/ g7 K1 `- i' [& w1 |) d- pragma solidity ^0.8.20;3 }& _4 r7 A# C
- import "@openzeppelin/contracts/token/ERC20/";
! h/ R; q. f: V1 C- contract MyToken is ERC20 {/ e6 z0 B4 I* f: N
constructor(uint256 initialSupply) ERC20("MyToken", "MTK") {2 \2 w5 C: p1 ]" o: D7 \
_mint(, initialSupply);2 r" \3 R% I( n4 [" @- R% O
}8 O3 b0 I) c; x0 a
}" ?( ^3 x. k; D3 A( C
- 说明
( S( O' R& x! E6 W. F- 名称与符号可自定义(如 "MyToken" / "MTK")/ @" M; h$ R- J/ J) x$ w
- initialSupply 为初始发行量(单位为最小单位 Wei,例如 18 位小数的代币需乘 10^18)
, a/ b8 q  P8 C3 b. N: d五、编写部署脚本
2 R- x) Y, l% j1 ^- 在 scripts/ 目录下创建 ,示例代码:' F- H% @* {* D; L# b
- const { ethers } = require("hardhat");
7 @+ t, h% L) Y9 o/ d- async function main() {  r7 q+ l" U! P' _
const initialSupply = ("100000000", 18); // 1亿枚,18位小数1 N# `9 l" K: Z# s  C6 C+ _# I
const token = await ("MyToken", [initialSupply]);, a  K9 P( A* z: |2 l  u2 q1 C
await ();
: P: D2 Z& a0 j0 y) X3 K("MyToken deployed to:", );
$ Q# \( \" D/ X2 d' @4 [}
9 N. b- D! ~6 [- main().catch((error) => {% U1 ]8 o3 d5 w. V
(error);+ _1 f( O. s: l: Q/ z' y
= 1;  t4 g1 j9 T2 m! R
});
# \: D9 a) T2 M+ ~" M. O: K6 ]$ a% v六、编译与部署到测试网(Sepolia)4 w+ M* O3 G+ v
- 编译:npx hardhat compile
9 F' ]9 m8 H  A. N( V- 部署:npx hardhat run scripts/ --network sepolia) T3 H0 k0 t2 T' ]/ v
- 运行成功会输出合约地址(MyToken deployed to: 0x...)
6 r  G: D' ?  h0 p6 l6 B- 在区块浏览器()查询该地址,确认合约已上链
4 U3 W1 b0 }' l5 w7 U七、可选:合约源码校验(便于他人查看源码与构造参数)
$ F) O3 x) z; u1 y: B, n6 Y: b- 命令:npx hardhat verify --network sepolia 合约地址 初始发行量(Wei)
2 t: w/ j& K' c" _; U0 C- 例:npx hardhat verify --network sepolia 0xYourTokenAddress5 _( W8 e( F% z# T2 g$ H/ K
100000000000000000000000000
6 Y6 U: F* t) b- 注意:这里的初始发行量需与部署脚本中的 initialSupply 完全一致(单位为 Wei)
, a6 M4 m2 M: r- i# ^0 s$ h八、在钱包中查看代币
' @9 Y' J$ i3 x: ~2 u, U# S, O- 打开 MetaMask,选择对应网络(Sepolia 或主网)
) L" ^: \+ k( J2 Y$ U9 d2 w- i- 选择“导入代币”,粘贴合约地址,确认代币符号与小数位(18)/ C/ Y0 W: s/ o
- 即可在钱包中看到初始发行的代币余额(在部署账户下)
# t- v+ t' @. [- f9 ?九、部署到主网(可选)
4 Y7 L& L% ^& `1 W" U- 确保 .env 中配置 MAINNET_RPC_URL、PRIVATE_KEY,且钱包内有主网 ETH
) _4 h8 X) I9 A3 J2 k- 命令:npx hardhat run scripts/ --network mainnet. H( A3 E3 I) U7 H( F
- 可用 Etherscan 校验:npx hardhat verify --network mainnet 合约地址 初始发行量(Wei)
* F8 G* u0 K0 M! G# P8 U十、常见问题与排查5 x3 N+ `( I) I6 p2 M. Z
- 部署报“insufficient funds for gas”:
/ |% K9 @) ~2 B+ o- 账户没有足够 ETH(测试网/主网),先充值再部署- N7 g! y0 P  q
- Ethers 版本导致的方法差异:  U& e& [2 t( m- T2 G
- 本教程基于 ethers v6(Hardhat Toolbox 默认),使用
3 T3 Q; {5 k9 n2 O2 p- 私钥与 .env:5 b: F0 @$ U6 s  d0 U& B
- PRIVATE_KEY 必须以 0x 开头,无引号与空格
" d) d+ p; R# ]; o( \- R- 确保 .gitignore 排除 .env,切勿泄露私钥! i  O) B% M+ d( A2 s# r0 P
- 构造参数不一致导致校验失败:
, L: I8 V; N9 R% w: g' K- verify 命令的初始发行量(Wei)必须与部署时完全一致8 D: ?" d9 Z& y8 I! V" I( u
到这里,你已经完成了一个标准 ERC‑20 代币从“编写 → 编译 → 部署 →(可选)校验 → 钱包查看”的完整最小流程。若你需要把名称/符号/小数位做成可配置,或加入可增发/销毁、暂停等扩展权限。
9 I9 `7 \) b* Y( s  L下面是一键发币的工具;/ k6 @8 t% Y# M( T: H7 x5 Q8 ^
这个星辰发币是目前最好用的一个一键发币的工具( ),不需要授权,代码干净;最推荐。3 _9 D5 q1 v) a! E" [4 d  a) s
这个dajgh也还可以但是需要授权( ),授权会带来一些安全方面的风险。% W2 H8 V( p- Q8 Y+ f) }" J# 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
这个需要有资格吧,个人是不可能的吧




欢迎光临 优惠论坛 (https://www.tcelue.ws/) Powered by Discuz! X3.1