"test": "echo "Error: no test specified" && exit 1"
},
"author": "",
"license": "ISC"
}
Is this ok? (yes) yes
$ npm install zeppelin-solidity
現在我們可以創建我們的通證合約了。創建一個 contracts/HamburgerCoin.sol 文件並加入如下內容:
pragma solidity ^0.4.18;
import "zeppelin-solidity/contracts/token/StandardToken.sol";
contract HamburgerCoin is StandardToken {
string public name = "HamburgerCoin";
string public symbol = "HBC";
uint public decimals = 2;
uint public INITIAL_SUPPLY = 10000 * (10 ** decimals);
function HamburgerCoin() public {
totalSupply_ = INITIAL_SUPPLY;
balances[msg.sender] = INITIAL_SUPPLY;
}
}
(LCTT 譯註:上述合約內容中指定了合約的名稱、符號和供應量。在 ERC20 當中,通證的供應量其實是整數,上述合約中通證的實際供應量是 10000 * 100 個,出於顯示 2 位小數的需求,你在合約瀏覽器、錢包軟件中看到和操作的 1 個通證,實際上在交易中是以 100 個進行的。)
OpenZepplin 的 StandardToken 是一個標準的 ERC20 通證。如果你感興趣,你可以看看它的 源代碼 以瞭解是如何工作的。
實際上並不太複雜。該合約有一個 地址到餘額 的映射(LCTT 譯註:你可以理解為哈希、關聯數組),它也有一個 允許轉賬 的列表。你可以看做是支票。你可以寫張支票,但是直到它被兌付前,錢並不會被轉賬。
如果有人要轉走一些資金,你可以在合約上調用 approve 方法,設置你要發送的通證數量。這就像是寫支票一樣。
然後調用 transferFrom 會實際進行轉賬。
我們可以從頭寫這些合約,但是最好採用經過完備的社區測試的合約。從頭寫一個 ERC20 通證那就是另外一篇文章了。
試著運行 compile 來編譯我們的合約:
$ truffle compile
Compiling ./contracts/HamburgerCoin.sol...
Compiling zeppelin-solidity/contracts/math/SafeMath.sol...
Compiling zeppelin-solidity/contracts/ownership/Ownable.sol...
Compiling zeppelin-solidity/contracts/token/BasicToken.sol...
Compiling zeppelin-solidity/contracts/token/ERC20.sol...
Compiling zeppelin-solidity/contracts/token/ERC20Basic.sol...
Compiling zeppelin-solidity/contracts/token/MintableToken.sol...
Compiling zeppelin-solidity/contracts/token/StandardToken.sol...
Writing artifacts to ./build/contracts Next you'll need to add a migration file which will tell truffle how to deploy your contract.
接下來我們需要增加一個 truffle 遷移 。
創建 migrations/2_deploy_hamburgercoin.js 文件並添加如下內容:
var HamburgerCoin = artifacts.require("./HamburgerCoin.sol");
module.exports = function(deployer) {
deployer.deploy(HamburgerCoin);
};
現在讓我們配置 truffle 以能夠使用 Infura 公共節點。如果我們要部署到公共節點,那就需要錢包的私鑰。我們可以將該私鑰包含在我們的源代碼當中,但是如果任何人可以訪問你的源代碼(和版本庫),他就能夠偷走我們所有的漢堡幣!要避免這種情況,我們會使用 dotenv node.js 模塊。(LCTT 譯註:dotenv 用於存儲機密信息的文件 .env 是以 “.” 開頭的,默認不會進入版本庫,當然,如果有人能查看你全部的項目文件,你的私鑰還是會被洩露。)
讓我們安裝部署到 Infura 所需的所有模塊。
npm install --save-dev dotenv truffle-wallet-provider ethereumjs-wallet
(LCTT 譯註:可能安裝過程中會有很多警告,大多應該是屬於定義了未使用的變量和方法的編譯警告,可以忽略。)
現在編輯 truffle.js 並(原樣)加入如下內容:
require('dotenv').config();
const Web3 = require("web3");
const web3 = new Web3();
const WalletProvider = require("truffle-wallet-provider");
const Wallet = require('ethereumjs-wallet');
var mainNetPrivateKey = Buffer.from(process.env["MAINNET_PRIVATE_KEY"], "hex")
var mainNetWallet = Wallet.fromPrivateKey(mainNetPrivateKey);
var mainNetProvider = new WalletProvider(mainNetWallet, "https://mainnet.infura.io/");
var ropstenPrivateKey = Buffer.from(process.env["ROPSTEN_PRIVATE_KEY"], "hex")
var ropstenWallet = Wallet.fromPrivateKey(ropstenPrivateKey);
var ropstenProvider = new WalletProvider(ropstenWallet, "https://ropsten.infura.io/");
module.exports = {
networks: {
development: {
host: "localhost",
port: 8545,
network_id: "*" // Match any network id
},
ropsten: {
provider: ropstenProvider,
// You can get the current gasLimit by running
// truffle deploy --network rinkeby
// truffle(rinkeby)> web3.eth.getBlock("pending", (error, result) =>
// console.log(result.gasLimit))
gas: 4600000,
gasPrice: web3.toWei("20", "gwei"),
network_id: "3",
},
mainnet: {
provider: mainNetProvider,
gas: 4600000,
gasPrice: web3.toWei("20", "gwei"),
network_id: "1",
}
}
};
(LCTT 譯註:原文采用 new Buffer 來獲取私鑰設置,但 node.js 升級後,廢棄了 new Buffer 這種用法,運行時會發出警告,所以上面我修改為使用 Buffer.from 。)
接下來我們從 Metamask 中得到我們的私鑰:
- 點擊你的 Chrome 窗口右上角的狐狸圖標。
- 點擊 “Account 1” 右側的省略號。
- 點擊 “Export Private Key”。
- 輸入你的密碼。
- 點擊該文字以複製私鑰到剪貼板。
然後打開 .env文件,並像下面這樣貼入你的私鑰(對於 Ropsten 測試網和 Mainnet 主網,你的私鑰是一樣的):
ROPSTEN_PRIVATE_KEY="123YourPrivateKeyHere"
MAINNET_PRIVATE_KEY="123YourPrivateKeyHere"
接下來,讓我們部署到 Ropsten 以太坊測試網。
以太坊測試網是一個你可以測試合約的地方。此外還有 Kovan 和 Rinkeby 測試網。我在這個教程中選擇 Ropsten 是因為現在很容易得到 Ropsten 的測試 ETH。這些測試網都類似,你可以使用任何一個你喜歡的,但是在此教程當中我假設你在使用 Ropsten。訪問 https://faucet.metamask.io/ 以得到一些測試 ETH。從 faucet 得到一些 ETH 後,你就可以部署了。
$ truffle deploy --network ropsten
Compiling ./contracts/HamburgerCoin.sol...
Compiling ./contracts/Migrations.sol...
Compiling zeppelin-solidity/contracts/math/SafeMath.sol...
Compiling zeppelin-solidity/contracts/token/BasicToken.sol...
Compiling zeppelin-solidity/contracts/token/ERC20.sol...
Compiling zeppelin-solidity/contracts/token/ERC20Basic.sol...
Compiling zeppelin-solidity/contracts/token/StandardToken.sol...
Writing artifacts to ./build/contracts
Using network 'ropsten'.
Running migration: 1_initial_migration.js
Deploying Migrations...
... 0xc2bbe6bf5a7c7c7312c43d65de4c18c51c4d620d5bf51481ea530411dcebc499
Migrations: 0xd827b6f93fcb50631edc4cf8e293159f0c056538
Saving successful migration to network...
... 0xe6f92402e6ca0b1d615a310751568219f66b9d78b80a37c6d92ca59af26cf475
Saving artifacts...
Running migration: 2_deploy_contracts.js
Deploying HamburgerCoin...
... 0x02c4d47526772dc524851fc2180b338a6b037500ab298fa2f405f01abdee21c4
HamburgerCoin: 0x973b1a5c753a2d5d3924dfb66028b975e7ccca51
Saving artifacts...
在 “Saving aritfacts” 上面的這行即是你的合約的新地址。
複製並黏貼該地址到 Ropsten Etherscan 搜索框 ,你就能看到你新部署的合約。
現在你可以在任何 ERC20 兼容的錢包,如 Mist 、 MyEtherWallet (LCTT 譯註:或 ImToken 這樣的手機應用)裡面使用你的通證了。
為了這篇教程,我構建了一個名為 Etherface 的錢包來做演示。
首先你需要添加你的通證到 Etherface:
- 訪問 http://etherface.io/ 。
- 確認你在 Metamask 中選擇了 “Ropsten” 網絡。
- 點擊 “Tokens”。
- 點擊右上角的加號按鈕。
- 輸入上面的合約地址。
如果你有朋友想要一些漢堡幣,你現在就可以發送給他們了。如果沒有,你也可以在你的兩個賬號間測試轉賬:
- 在 Metamask 中點擊 “切換賬號”按鈕(在右上角),並改變你的賬號為 “Account 2”。
- 點擊 “Account 2” 右邊的省略號,然後選擇 “Copy Address to clipboard”。
- 切換回 “Account 1”,這很重要!否則交易會失敗。
- 在 Etherface 中你的餘額下點擊 “Send”。
- 黏貼 “Account 2” 的地址。
- 輸入你要發送的數量。
- Metamask 會彈出確認窗口,點擊 “Submit”。
- 等大約 15-30 秒。
- 你的 “Account 1” 的餘額應該會減少,“Account 2” 現在會有了一些漢堡幣!
最後,讓我們來部署到主網(LCTT 譯註:這會花費你真實的 ETH,你可以通過查看前面部署到 Ropsten 的合約信息中瞭解花費了多少 gas,以相應估計實際要花費多少 ETH):
$ truffle deploy --network mainnet
你可以如前面一樣加你的通證到 Etherface ,併發送你新打造的通證給你的朋友們了!
閱讀更多 Linux技術 的文章