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. 成功
相关推荐
天涯学馆11 小时前
Solidity中实现安全的代币转账
智能合约·solidity·以太坊
yiyesushu19 小时前
solidity+chainlink 项目实例
solidity
木西2 天前
React Native DApp 开发全栈实战·从 0 到 1 系列(兑换-合约部分)
web3·智能合约·solidity
.刻舟求剑.4 天前
solidity得高级语法3
区块链·solidity·语法笔记
许强0xq4 天前
Ethernaut Level 1: Fallback - 回退函数权限提升攻击
区块链·solidity·foundry·ethernaut
.刻舟求剑.5 天前
solidity的高阶语法4
区块链·solidity·语法笔记
大白猴6 天前
【GMX v1实战】时序风险结算与资本成本:深度解析 GMX 永续合约的资金费率机制
区块链·智能合约·solidity·永续合约·gmx·资金费率·去中心化交易所
天涯学馆8 天前
在Solidity中实现DAO:从概念到代码的全面剖析
智能合约·solidity·以太坊
大白猴13 天前
【大白话解析】OpenZeppelin 的 ReentrancyGuard 库:以太坊防重入攻击安全工具箱(附源代码)
区块链·智能合约·solidity·以太坊·evm·重入攻击·恶意合约
木西14 天前
React Native DApp 开发全栈实战·从 0 到 1 系列(流动性挖矿-合约部分)
web3·智能合约·solidity