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. 成功
相关推荐
0x派大星3 天前
Solidity 存储和内存管理:深入理解与高效优化
web3·区块链·智能合约·solidity
0x派大星4 天前
Solidity智能合约中的事件和日志
web3·区块链·智能合约·solidity
0x派大星7 天前
Solidity——抽象合约和接口详解
区块链·智能合约·solidity
0x派大星8 天前
Solidity智能合约中的异常处理(error、require 和 assert)
区块链·智能合约·solidity
阿菜ACai1 个月前
【漏洞分析】OSN 代币攻击事件:一笔资金伪造多个分红大户
智能合约·漏洞分析·solidity
许强0xq1 个月前
Solidity&Foundry Merkle Airdrop
区块链·智能合约·solidity
龑行天下2 个月前
solidity 以太坊(Ether) 单位(很基础)
区块链·solidity
龑行天下2 个月前
solidity时间单位(基础很重要)
区块链·solidity
龑行天下2 个月前
solidity合约销毁(带销毁例子很常见)
区块链·solidity
龑行天下2 个月前
solidity合约创建
区块链·智能合约·solidity