IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> 区块链 -> ERC20 代币协议 -> 正文阅读

[区块链]ERC20 代币协议

ERC20 代币协议

写在最前

空气币这么无聊的东西为什么有人信?

开始教程

ERC20 代币的开发流程可分为两步

  1. 定义 ERC20 代币标准接口
  2. 代币协议继承标准接口

ERC20 标准接口

pragma solidity ^0.4.20;
 
// 定义ERC-20标准接口
 
contract ERC20Interface {
 
    // 代币名称
 
    string public name;
 
    // 代币符号或者说简写
 
    string public symbol;
 
    // 代币小数点位数,代币的最小单位
 
    uint8 public decimals;
 
    // 代币的发行总量
 
    uint public totalSupply;
 
 
 
    // 实现代币交易,用于给某个地址转移代币
 
    function transfer(address to, uint tokens) public returns (bool success);
 
    // 实现代币用户之间的交易,从一个地址转移代币到另一个地址
 
    function transferFrom(address from, address to, uint tokens) public returns (bool success);
 
    // 允许spender多次从你的账户取款,并且最多可取tokens个,主要用于某些场景下授权委托其他用户从你的账户上花费代币
 
    function approve(address spender, uint tokens) public returns (bool success);
 
    // 查询spender允许从tokenOwner上花费的代币数量
 
    function allowance(address tokenOwner, address spender) public view returns (uint remaining);
 
 
 
    // 代币交易时触发的事件,即调用transfer方法时触发
 
    event Transfer(address indexed from, address indexed to, uint tokens);
 
    // 允许其他用户从你的账户上花费代币时触发的事件,即调用approve方法时触发
 
    event Approval(address indexed tokenOwner, address indexed spender, uint tokens);
 
}

继承 ERC20 接口

// 实现ERC-20标准接口
 
contract ERC20Impl is ERC20Interface {
 
    // 存储每个地址的余额(因为是public的所以会自动生成balanceOf方法)
 
    mapping (address => uint256) public balanceOf;
 
    // 存储每个地址可操作的地址及其可操作的金额
 
    mapping (address => mapping (address => uint256)) internal allowed;
 
 
 
    // 初始化属性
 
    constructor() public {
 
        name = "TestByteGoToken";             // 定义 代币名称
 
        symbol = "TBG22";                           // 代币的简写
 
        decimals = 18;
 
        totalSupply = 100000000 * 10 ** uint256(decimals);       // 代币总量
 
        // 初始化该代币的账户会拥有所有的代币
 
        balanceOf[msg.sender] = totalSupply;                    // 初始化的时候,这个代币属于谁
 
    }
 
 
 
    function transfer(address to, uint tokens) public returns (bool success) {
 
        // 检验接收者地址是否合法
 
        require(to != address(0));
 
        // 检验发送者账户余额是否足够
 
        require(balanceOf[msg.sender] >= tokens);
 
        // 检验是否会发生溢出
 
        require(balanceOf[to] + tokens >= balanceOf[to]);
 
 
 
        // 扣除发送者账户余额
 
        balanceOf[msg.sender] -= tokens;
 
        // 增加接收者账户余额
 
        balanceOf[to] += tokens;
 
 
 
        // 触发相应的事件
 
        emit Transfer(msg.sender, to, tokens);
 
    }
 
 
 
    function transferFrom(address from, address to, uint tokens) public returns (bool success) {
 
        // 检验地址是否合法
 
        require(to != address(0) && from != address(0));
 
        // 检验发送者账户余额是否足够
 
        require(balanceOf[from] >= tokens);
 
        // 检验操作的金额是否是被允许的
 
        require(allowed[from][msg.sender] <= tokens);
 
        // 检验是否会发生溢出
 
        require(balanceOf[to] + tokens >= balanceOf[to]);
 
 
 
        // 扣除发送者账户余额
 
        balanceOf[from] -= tokens;
 
        // 增加接收者账户余额
 
        balanceOf[to] += tokens;
 
 
 
        // 触发相应的事件
 
        emit Transfer(from, to, tokens);  
 
 
 
        success = true;
 
    }
 
 
 
    function approve(address spender, uint tokens) public returns (bool success) {
 
        allowed[msg.sender][spender] = tokens;
 
        // 触发相应的事件
 
        emit Approval(msg.sender, spender, tokens);
 
 
 
        success = true;
 
    }
 
 
 
    function allowance(address tokenOwner, address spender) public view returns (uint remaining) {
 
        return allowed[tokenOwner][spender];
 
    }
 
}

最后的样子

pragma solidity ^0.4.20;
 
// 定义ERC-20标准接口
 
contract ERC20Interface {
 
    // 代币名称
 
    string public name;
 
    // 代币符号或者说简写
 
    string public symbol;
 
    // 代币小数点位数,代币的最小单位
 
    uint8 public decimals;
 
    // 代币的发行总量
 
    uint public totalSupply;
 
 
 
    // 实现代币交易,用于给某个地址转移代币
 
    function transfer(address to, uint tokens) public returns (bool success);
 
    // 实现代币用户之间的交易,从一个地址转移代币到另一个地址
 
    function transferFrom(address from, address to, uint tokens) public returns (bool success);
 
    // 允许spender多次从你的账户取款,并且最多可取tokens个,主要用于某些场景下授权委托其他用户从你的账户上花费代币
 
    function approve(address spender, uint tokens) public returns (bool success);
 
    // 查询spender允许从tokenOwner上花费的代币数量
 
    function allowance(address tokenOwner, address spender) public view returns (uint remaining);
 
 
 
    // 代币交易时触发的事件,即调用transfer方法时触发
 
    event Transfer(address indexed from, address indexed to, uint tokens);
 
    // 允许其他用户从你的账户上花费代币时触发的事件,即调用approve方法时触发
 
    event Approval(address indexed tokenOwner, address indexed spender, uint tokens);
 
}
 
 
 
// 实现ERC-20标准接口
 
contract ERC20Impl is ERC20Interface {
 
    // 存储每个地址的余额(因为是public的所以会自动生成balanceOf方法)
 
    mapping (address => uint256) public balanceOf;
 
    // 存储每个地址可操作的地址及其可操作的金额
 
    mapping (address => mapping (address => uint256)) internal allowed;
 
 
 
    // 初始化属性
 
    constructor() public {
 
        name = "TestByteGoToken";             // 定义 代币名称
 
        symbol = "TBG22";                           // 代币的简写
 
        decimals = 18;
 
        totalSupply = 100000000 * 10 ** uint256(decimals);       // 代币总量
 
        // 初始化该代币的账户会拥有所有的代币
 
        balanceOf[msg.sender] = totalSupply;                    // 初始化的时候,这个代币属于谁
 
    }
 
 
 
    function transfer(address to, uint tokens) public returns (bool success) {
 
        // 检验接收者地址是否合法
 
        require(to != address(0));
 
        // 检验发送者账户余额是否足够
 
        require(balanceOf[msg.sender] >= tokens);
 
        // 检验是否会发生溢出
 
        require(balanceOf[to] + tokens >= balanceOf[to]);
 
 
 
        // 扣除发送者账户余额
 
        balanceOf[msg.sender] -= tokens;
 
        // 增加接收者账户余额
 
        balanceOf[to] += tokens;
 
 
 
        // 触发相应的事件
 
        emit Transfer(msg.sender, to, tokens);
 
    }
 
 
 
    function transferFrom(address from, address to, uint tokens) public returns (bool success) {
 
        // 检验地址是否合法
 
        require(to != address(0) && from != address(0));
 
        // 检验发送者账户余额是否足够
 
        require(balanceOf[from] >= tokens);
 
        // 检验操作的金额是否是被允许的
 
        require(allowed[from][msg.sender] <= tokens);
 
        // 检验是否会发生溢出
 
        require(balanceOf[to] + tokens >= balanceOf[to]);
 
 
 
        // 扣除发送者账户余额
 
        balanceOf[from] -= tokens;
 
        // 增加接收者账户余额
 
        balanceOf[to] += tokens;
 
 
 
        // 触发相应的事件
 
        emit Transfer(from, to, tokens);  
 
 
 
        success = true;
 
    }
 
 
 
    function approve(address spender, uint tokens) public returns (bool success) {
 
        allowed[msg.sender][spender] = tokens;
 
        // 触发相应的事件
 
        emit Approval(msg.sender, spender, tokens);
 
 
 
        success = true;
 
    }
 
 
 
    function allowance(address tokenOwner, address spender) public view returns (uint remaining) {
 
        return allowed[tokenOwner][spender];
 
    }
 
}
最后劝君多花些时间在正经事情上,别老想着投机
  区块链 最新文章
盘点具备盈利潜力的几大加密板块,以及潜在
阅读笔记|让区块空间成为商品,打造Web3云
区块链1.0-比特币的数据结构
Team Finance被黑分析|黑客自建Token“瞒天
区块链≠绿色?波卡或成 Web3“生态环保”标
期货从入门到高深之手动交易系列D1课
以太坊基础---区块验证
进入以太坊合并的五个数字
经典同态加密算法Paillier解读 - 原理、实现
IPFS/Filecoin学习知识科普(四)
上一篇文章      下一篇文章      查看所有文章
加:2022-02-14 21:11:42  更:2022-02-14 21:11:52 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2024年12日历 -2024/12/28 19:15:09-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码
数据统计