教你如何在以太坊上创建属于自己的ERC20代币

本文从技术角度详细介绍如何基于以太坊ERC20创建代币的流程。
(需要帮忙代做的可以联系V信:WangSanfeng0417)

写在前面
本文所讲的代币是使用以太坊智能合约创建,阅读本文前,你应该对以太坊、智能合约有所了解,如果你还不了解,建议你先看以太坊是什么

代币Token
如果不那么追求精确的定义,代币就是数字货币,比特币、以太币就是一个代币。

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

因此不管是出于商业,还是学习很多人想创建一个自己的代币,先贴一个图看看创建的代币是什么样子。

在这里插入图片描述

今天我们就来具体讲一讲怎样创建一个这样的代币。

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

要求我们在实现代币的时候必须要遵守的协议,如指定代币名称、总量、实现代币交易函数等,只有支持了协议才能被以太坊钱包支持。

其接口如下:

在这里插入图片描述

简单说明一下:

name : 代币名称

symbol: 代币符号

decimals: 代币小数点位数,代币的最小单位, 18表示我们可以拥有 .0000000000000000001单位个代币。

totalSupply() : 发行代币总量。

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

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

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

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,配置好之后,界面应该如下:

浏览器打开Remix Solidity IDE,复制以上源码粘贴上。

在这里插入图片描述

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

这时MetaMask会弹出一个交易确认框,点SUBMIT。待合约部署交易确认之后,复制合约地址(部署合约需消耗以太币,消耗多少取决于以太网络拥堵程度)。

  1. 打开Metamask界面,切换到TOKENS,点添加合约,出现如下对话框:

填入刚刚复制的地址,点ADD,这时你就可以看到你创建的代币了,如图:

在这里插入图片描述

哈哈,你已经完成了代币的创建和部署(正式网络和测试网络部署方法一样),可以在Etherscan查询到我们刚刚部署的代币。可以用它进行爱希欧了,从此走上人生巅峰(玩笑话,不鼓励大家发行无意义的代币)。

在这里插入图片描述

PS:如果你既不想折腾,还想要拥有自己专属代币的话,那就点击关注然后私聊找我喽,我可以代为帮你完成定制,你只需告诉我代币名称、数量和接收地址即可,价格很是美丽的呢,偷偷告诉你,代币名称还支持中文哦

可以加下面qq群详细了解:
在这里插入图片描述

猜你喜欢

转载自blog.csdn.net/weixin_43265055/article/details/82821569