最新內容會更新在主站深刻淺出區塊鏈社區
原文連接:建立本身的數字貨幣(ERC20 代幣)進行 ICOphp
本文從技術角度詳細介紹如何基於以太坊ERC20建立代幣的流程.html
本文所講的代幣是使用以太坊智能合約建立,閱讀本文前,你應該對以太坊、智能合約有所瞭解,若是你還不瞭解,建議你先看以太坊是什麼git
若是不那麼追求精確的定義,代幣就是數字貨幣,比特幣、以太幣就是一個代幣。
利用以太坊的智能合約能夠輕鬆編寫出屬於本身的代幣,代幣能夠表明任何能夠交易的東西,如:積分、財產、證書等等。
所以不論是出於商業,仍是學習不少人想建立一個本身的代幣,先貼一個圖看看建立的代幣是什麼樣子。
github
今天咱們就來詳細講一講怎樣建立一個這樣的代幣。瀏覽器
也許你常常看到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); }
簡單說明一下:
name : 代幣名稱
symbol: 代幣符號
decimals: 代幣小數點位數,代幣的最小單位, 18表示咱們能夠擁有 .0000000000000000001單位個代幣。
totalSupply() : 發行代幣總量。
balanceOf(): 查看對應帳號的代幣餘額。
transfer(): 實現代幣交易,用於給用戶發送代幣(從咱們的帳戶裏)。
transferFrom(): 實現代幣用戶之間的交易。
allowance(): 控制代幣的交易,如可交易帳號及資產。
approve(): 容許用戶可花費的代幣數。網絡
代幣合約代碼:app
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; } }
代碼的詳細解讀,請訂閱個人小專欄。ide
在開發測試智能合約時,MetaMask和Remix Solidity IDE是兩個很是好用的工具,今天就用他們來完成部署。函數
安裝和配置MetaMask請參考開發、部署第一個去中心化應用,不一樣的上本文選擇了以太坊的測試網絡Ropsten,若是你沒有餘額請點擊購買buy,進入的網站能夠送一些測試以太幣給你,配置好以後,界面應該以下:
瀏覽器打開Remix Solidity IDE,複製以上源碼粘貼上,在右側選項參考如圖的設置:
注意Environment和Account和MetaMask保持一致,而後選擇合約TokenERC20,填入你想要的發行量,名稱及代號,就能夠建立合約了。
這時MetaMask會彈出一個交易確認框,點SUBMIT。待合約部署交易確認以後,複製合約地址。
打開Metamask界面,切換到TOKENS,點添加合約,出現以下對話框:
填入剛剛複製的地址,點ADD,這時你就能夠看到你建立的代幣了,如圖:
哈哈,你已經完成了代幣的建立和部署(正式網絡和測試網絡部署方法同樣),能夠在Etherscan查詢到咱們剛剛部署的代幣。能夠用它進行ICO了,今後走上人生巔峯(玩笑話,不鼓勵你們發行無心義的代幣)。
因爲MetaMask插件沒有提供代幣交易功能,同時考慮到不少人並無以太坊錢包或是被以太坊錢包網絡同步問題折磨,今天我用網頁錢包來說解代幣交易。
代幣交易是否是很簡單,只要明白了交易流程,使用其餘的錢包也是同樣的道理。
若是你在建立代幣的過程當中遇到問題,個人知識星球可爲你們解答問題。
系統的學習區塊鏈技術能夠前往區塊鏈技術學習指引
如何建立代幣發行代幣,如今也錄製了對應的視頻教程:經過代幣學以太坊智能合約開發
若是你想和認識我,想和我一塊兒交流區塊鏈技術,歡迎加入個人知識星球深刻淺出區塊鏈,
目前咱們也在招募體驗師,能夠點擊連接瞭解。
我也會在星球裏爲你們解答區塊鏈技術問題,做爲星友福利,星友可加入我常見的區塊鏈技術付費交流羣,交流羣內已經彙集了100多位區塊鏈技術愛好者。
深刻淺出區塊鏈 - 系統學習區塊鏈,打造最好的區塊鏈技術博客。