solidity 铸造自己的ERC20代币Demo

目的

懂技术原理才不会被骗

适用人群

  • 有solidity 基础
  • 有一定的前端基础至少会js
  • 有区块连基础知识

开始写你的demo

sol 复制代码
// SPDX-License-Identifier: MIT
pragma solidity ^0.8.0;

// 了解有关 ERC20 实施的更多信息
// 在 OpenZeppelin 文档上:https://docs.openzeppelin.com/contracts/4.x/erc20
import "@openzeppelin/contracts/token/ERC20/ERC20.sol";

contract ERC20MSHKToken is ERC20 {

    // MSHK ERC20 Token 代币名字
    // MSHK 代币简称
    constructor() ERC20("MSHK ERC20 Token", "MSHK") {
        // msg.sender 合约调用者
        // 向合约创建者发送 100000 个有18位小数的代币
        _mint(msg.sender, 100000 * 10 ** 18);
    }
}

好了这就完成了,是不是很简单!

不开玩笑,实际上我们的合约通常通过继承来创建,在这里我们使用了ERC20来实现基本接口,并设置了namesymbol,decimals作为可选项。另外,我们设置了token的initialSupply参数,所有的代币将会分配给部署此合约的地址。

ERC20 又是继承了IERC20.

使用的标准的接口合约

  • IERC20 IERC20ERC20代币标准的接口合约,规定了ERC20代币需要实现的函数和事件。 之所以需要定义接口,是因为有了规范后,就存在所有的ERC20代币都通用的函数名称,输入参数,输出参数

IERC20定义了2个事件:Transfer事件和Approval事件,分别在转账和授权时被释放:

sol 复制代码
/**  
* @dev 释放条件:当 `value` 单位的货币从账户 (`from`) 转账到另一账户 (`to`)时.  
*/  
event Transfer(address indexed from, address indexed to, uint256 value);  
  
/**  
* @dev 释放条件:当 `value` 单位的货币从账户 (`owner`) 授权给另一账户 (`spender`)时.  
*/  
event Approval(address indexed owner, address indexed spender, uint256 value);

IERC20定义了6个函数,提供了转移代币的基本功能,并允许代币获得批准,以便其他链上第三方使用

sol 复制代码
/**  
* @dev 返回代币总供给.  
*/  
function totalSupply() external view returns (uint256);

/**  
* @dev 返回账户`account`所持有的代币数.  
*/  
function balanceOf(address account) external view returns (uint256);

/**  
* @dev 转账 `amount` 单位代币,从调用者账户到另一账户 `to`.  
*  
* 如果成功,返回 `true`.  
*  
* 释放 {Transfer} 事件.  
*/  
function transfer(address to, uint256 amount) external returns (bool);

/**  
* @dev 返回`owner`账户授权给`spender`账户的额度,默认为0。  
*  
* 当{approve} 或 {transferFrom} 被调用时,`allowance`会改变.  
*/  
function allowance(address owner, address spender) external view returns (uint256);

 /**
 * @dev 调用者账户给`spender`账户授权 `amount`数量代币。
 *
 * 如果成功,返回 `true`.
 *
 * 释放 {Approval} 事件.
 */
function approve(address spender, uint256 amount) external returns (bool);

/**  
* @dev 通过授权机制,从`from`账户向`to`账户转账`amount`数量代币。转账的部分会从调用者的`allowance`中扣除。  
*  
* 如果成功,返回 `true`.  
*  
* 释放 {Transfer} 事件.  
*/  
function transferFrom(  
address from,  
address to,  
uint256 amount  
) external returns (bool);

到这一个合约就写完了

部署

Remix: remix.ethereum.org/

  1. 在contracts下写你的合约
  1. 编译
  1. 部署上链
  1. 成功
相关推荐
木西5 小时前
深度拆解 Web3 预测市场:基于 Solidity 0.8.24 与 UMA 乐观预言机的核心实现
web3·智能合约·solidity
木西8 天前
揭秘 Web3 隐私社交标杆:CocoCat 的核心架构与智能合约实现
web3·智能合约·solidity
木西9 天前
深度拆解 Grass 模式:基于 EIP-712 与 DePIN 架构的奖励分发系统实现
web3·智能合约·solidity
木西13 天前
深度解析|Form Network:BNX 迁移模块化 L2 的全流程技术实践
web3·智能合约·solidity
木西15 天前
STEPN相关内容延续篇:基于OpenZeppelinV5与Solidity0.8.24的创新点拆解
web3·智能合约·solidity
木西16 天前
深度实战:用 Solidity 0.8.24 + OpenZeppelin V5 还原 STEPN 核心机制
web3·智能合约·solidity
木西19 天前
实战|DeLinkedIn 全栈开发:Web3 身份验证 + 数字资产确权,搭建职场社交新生态
web3·智能合约·solidity
Rockbean23 天前
10分钟智能合约:进阶实战-3.3 拒绝服务攻击
web3·智能合约·solidity
Rockbean24 天前
10分钟智能合约:进阶实战-3.2.2 跨函数重入
web3·智能合约·solidity
Rockbean24 天前
10分钟智能合约:进阶实战-3.2.3 跨合约重入
web3·智能合约·solidity