主页 > imtoken老版本 > 教你一步步打造自己的ICO数字货币(代币)

教你一步步打造自己的ICO数字货币(代币)

imtoken老版本 2023-02-24 06:49:28

主站最新内容更新,简单讲解区块链社区

原文链接:为ICO创建自己的数字货币(ERC20代币)

本文从技术角度详细介绍了如何基于以太坊ERC20创建代币的过程。

写在前面

本文中描述的代币是使用以太坊智能合约创建的。在阅读本文之前,如果你还不知道,我建议你看看以太坊是什么。

令牌

如果不追求精确定义,代币就是数字货币,比特币如何自己生成虚拟币地址,以太坊就是代币。

使用以太坊的智能合约,你可以轻松编写自己的代币,代币可以代表任何可以交易的东西,比如积分、财产、证书等。

因此,无论是商务还是学习,很多人都想创建自己的token,先发图看看创建的token是什么样子的。

今天我们将详细讨论如何创建这样的令牌。

如何自己生成虚拟币地址

ERC20 代币

也许你经常看到ERC20和代币一起出现,ERC20是以太坊定义的代币标准。

我们在实现代币时必须遵守的协议,例如指定代币名称、总量、实现代币交易功能等,只有在协议支持的情况下,以太坊钱包才能支持。

界面如下:

contract ERC20Interface {
    string public constant name = "Token Name";
    string public constant symbol = "SYM";
    uint8 public constant decimals = 18;  // 18 is the most common number of decimal places
    function totalSupply() public constant returns (uint);
    function balanceOf(address tokenOwner) public constant returns (uint balance);
    function allowance(address tokenOwner, address spender) public constant returns (uint remaining);
    function transfer(address to, uint tokens) public returns (bool success);
    function approve(address spender, uint tokens) public returns (bool success);
    function transferFrom(address from, address to, uint tokens) public returns (bool success);
    event Transfer(address indexed from, address indexed to, uint tokens);
    event Approval(address indexed tokenOwner, address indexed spender, uint tokens);
}

简要说明:

名称:令牌名称

符号:令牌符号

小数:token小数位,token的最小单位,18表示我们可以有0.0000000000000000001个token单位。

如何自己生成虚拟币地址

totalSupply() : 发行代币总量。

balanceOf():查看对应账户的代币余额。

transfer():实现一个代币交易,将代币发送给用户(从我们的账户)。

transferFrom():实现token用户之间的交易。

allowance():控制代币的交易,例如可交易的账户和资产。

approve():允许用户消费的代币数量。

编写代币合约代码

代币合约代码:

pragma solidity ^0.4.16;
interface tokenRecipient { function receiveApproval(address _from, uint256 _value, address _token, bytes _extraData) public; }
contract TokenERC20 {
    string public name;
    string public symbol;
    uint8 public decimals = 18;  // 18 是建议的默认值
    uint256 public totalSupply;
    mapping (address => uint256) public balanceOf;  // 
    mapping (address => mapping (address => uint256)) public allowance;
    event Transfer(address indexed from, address indexed to, uint256 value);
    event Burn(address indexed from, uint256 value);
    function TokenERC20(uint256 initialSupply, string tokenName, string tokenSymbol) public {
        totalSupply = initialSupply * 10 ** uint256(decimals);
        balanceOf[msg.sender] = totalSupply;
        name = tokenName;
        symbol = tokenSymbol;
    }
    function _transfer(address _from, address _to, uint _value) internal {
        require(_to != 0x0);
        require(balanceOf[_from] >= _value);
        require(balanceOf[_to] + _value > balanceOf[_to]);
        uint previousBalances = balanceOf[_from] + balanceOf[_to];
        balanceOf[_from] -= _value;
        balanceOf[_to] += _value;
        Transfer(_from, _to, _value);
        assert(balanceOf[_from] + balanceOf[_to] == previousBalances);
    }
    function transfer(address _to, uint256 _value) public {
        _transfer(msg.sender, _to, _value);
    }
    function transferFrom(address _from, address _to, uint256 _value) public returns (bool success) {
        require(_value <= allowance[_from][msg.sender]);     // Check allowance
        allowance[_from][msg.sender] -= _value;
        _transfer(_from, _to, _value);
        return true;
    }
    function approve(address _spender, uint256 _value) public
        returns (bool success) {
        allowance[msg.sender][_spender] = _value;
        return true;
    }
    function approveAndCall(address _spender, uint256 _value, bytes _extraData) public returns (bool success) {
        tokenRecipient spender = tokenRecipient(_spender);
        if (approve(_spender, _value)) {
            spender.receiveApproval(msg.sender, _value, this, _extraData);
            return true;
        }
    }
    function burn(uint256 _value) public returns (bool success) {
        require(balanceOf[msg.sender] >= _value);
        balanceOf[msg.sender] -= _value;
        totalSupply -= _value;
        Burn(msg.sender, _value);
        return true;
    }
    function burnFrom(address _from, uint256 _value) public returns (bool success) {
        require(balanceOf[_from] >= _value);
        require(_value <= allowance[_from][msg.sender]);
        balanceOf[_from] -= _value;
        allowance[_from][msg.sender] -= _value;
        totalSupply -= _value;
        Burn(_from, _value);
        return true;
    }
}

如何自己生成虚拟币地址

代码详细解读,请订阅我的小专栏。

部署

MetaMask 和 Remix Solidity IDE 是开发和测试智能合约时非常有用的两个工具。立即使用它们完成部署。

要安装和配置 MetaMask,请参阅开发和部署第一个去中心化应用程序。上篇文章选择了以太坊的测试网络Ropsten。如果您没有余额,请点击购买购买。您输入的网站可以向您发送一些测试以太币。配置完成后界面如下:

在浏览器中打开Remix Solidity IDE,复制粘贴以上源码,右侧的选项参考如图设置:

注意Environment和Account和MetaMask一致,然后选择合约TokenERC20,填写你想要的发行量。名称和代号,可以创建合约。

此时MetaMask会弹出交易确认框,点击提交。合约部署交易确认后,复制合约地址。

如何自己生成虚拟币地址

打开Metamask界面,切换到TOKENS如何自己生成虚拟币地址,点击Add Contract,会出现如下对话框:

填写刚才复制的地址,点击ADD,就可以看到自己创建的token了,如图:

哈哈,你已经完成了token的创建和Deploy(官网和测试网部署方式相同),你可以在Etherscan上查询我们刚刚部署的token。你可以用它来进行ICO,从此你将达到人生的巅峰(开个玩笑,不要鼓励大家发行无意义的代币)。

代币交易

由于MetaMask插件不提供代币交易功能,并且考虑到很多人没有以太坊钱包或者被以太坊钱包的网络同步问题折磨,今天我就用网页钱包来讲解代币交易。

回车,第一次进入时有一些安全提示需要用户确认。进入后按照下图设置:

如何自己生成虚拟币地址

连接后,如图

要添加代币,请填写代币合约地址。执行代币转账交易

在下一次交易确认中,点击确认。交易完成后,可以看到MetaMask中的代币余额减少了,如图:

代币交易是不是很简单,只要了解交易流程,使用其他钱包也是如此。

如何创建代币发行代币,现在还录制了相应的**视频教程:通过代币学习以太坊智能合约开发,我们目前正在招聘经验专家**,您可以点击链接了解更多。

如果您在创建代币时遇到问题,我的**知识星球**可以回答您的问题。

参考文件

区块链通俗易懂——系统学习区块链,打造最好的区块链技术博客。