以太坊代币发行,python web3 加密数字货币交易与智能合约.
最近做个一些区块链外包相关的项目,现在总结下以太坊代币发行,以及区块链接入的过程。有兴趣可以去看看,摩尔支付。后台是基于django rest framwork, 就是python 啦. 前台就是vue与angularjs.下面主要总结下区块链相关的开发工作。首先要接入以太坊,使用geth客户端, 操作系统centos7.安装完毕后同步区块,最初用的是虚拟机,结果eth测试网...
最近做个一些区块链外包相关的项目,现在总结下以太坊代币发行,以及区块链接入的过程。有兴趣可以去看看,摩尔支付。
后台是基于django rest framwork, 就是python 啦. 前台就是vue与angularjs.
下面主要总结下区块链相关的开发工作。
首先要接入以太坊,使用geth客户端, 操作系统centos7.
安装完毕后同步区块,最初用的是虚拟机,结果eth测试网就同步了两周。后来换了一台高性能PC,1天就同步完成了。
区块同步完成后,eth.syncing 显示为false. 这时可以用一些基本的命令与以太坊网络进行交互。
因为后台用的是PYTHON,所以基于python web3是首选。版本要求3.6以上. 不得不升级python.
测试网络无论是转ETH或代币都很快,速度在10秒以内。
以太坊发币比较简单,贴下合约代码.
interface tokenRecipient { function receiveApproval(address _from, uint256 _value, address _token, bytes _extraData) public; }
contract Ownable {
address public owner;
function Ownable(){
owner = msg.sender;
}
/**
* 判断当前用户是否是合约所有人
*/
modifier onlyOwner () {
require(msg.sender == owner);
_;
}
}
contract TokenERC20 is Ownable{
string public name;
string public symbol;
uint8 public decimals = 2; // 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 Mint(address indexed to, uint256 amount);
event Burn(address indexed from, uint256 value);
function transferOwnership(address newOwner) onlyOwner public{
require(newOwner != address(0));
owner = newOwner;
}
function TokenERC20(uint256 initialSupply, string tokenName, string tokenSymbol) public {
totalSupply = initialSupply * 10 ** uint256(decimals);
balanceOf[msg.sender] = totalSupply;
name = tokenName;
symbol = tokenSymbol;
}
function mint(address _to, uint256 _amount) onlyOwner public returns (bool){
totalSupply += _amount * 10 ** uint256(decimals);
balanceOf[_to] += _amount * 10 ** uint256(decimals);
Mint(_to, _amount);
return true;
}
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;
}
}
这个是标准ERC20代币,创建合约时指定发行货币数量,并提供转账,销毁等标准接口。
这里预留了一个增发代币的接口。只有owner可以增发。
合约的开发与调试可以在 remix 中完成。
合约调用可以使用python web3。贴一下关键的代码。
web3 = Web3(HTTPProvider(ETH_SERVER))
contract = web3.eth.contract(abi=MOL_ABI, address=Web3.toChecksumAddress(ETH_MOL_ADDRESS))
muser = MUser.objects.get(user_id=userid)
ret = web3.personal.unlockAccount(Web3.toChecksumAddress(muser.eth), muser.eth_pass, 60)
if ret:
param = []
param.append(str(dst_address))
param.append(int(float(amount) * 100))
res = contract.transact({'from': Web3.toChecksumAddress(muser.eth), 'gas': 90000}).transfer(Web3.toChecksumAddress(param[0]), param[1])
# tx_hash = to_hex(res)
# return tx_hash
# print(web3.toText(res))
else:
print("trans mol failed")
步骤就是 1,初始化合约 2,解锁以太坊地址 3,通过合约转移代币。
这样就可以控制合约转账了。
更多推荐
所有评论(0)