以太坊代币发行,python web3 加密数字货币交易与智能合约.

 

最近做个一些区块链外包相关的项目,现在总结下以太坊代币发行,以及区块链接入的过程。有兴趣可以去看看,摩尔支付

后台是基于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,通过合约转移代币。

这样就可以控制合约转账了。

 

 

  • 2
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值