使用PHP开发以太坊代币与合约——以太坊交易

作者: 有丫 | 来源:发表于2019-08-28 10:53 被阅读0次
         $transaction = new Transaction([
                'nonce' => "$nonce",
                'from' => $from,
                'to' => $to,
                'gas' => '0x76c0',
                'gasPrice' => "$gasPrice",
                'value' => "$eth",
                'chainId' => $this->getChainId(),
            ]);
    

    这是一个以太坊交易必须的几个参数,使用web3p/ethereum-tx

    参数名 说明
    nonce 当前账户交易种子数
    from 发起账户
    to 目标账户
    gas 汽油限量
    gasPrice 汽油单价
    value 转账eth数量
    chainId 对应的链ID

    除此之外,如果是调用智能合约方法,还需要传入data参数。
    所有参数传完,最后需要对于整个参数列表使用私钥签名:

    $raw = $transaction->sign($privateKey);
    

    签名后获得的$raw就是sendRawTransaction需要的参数。

    这里对于几个参数进行着重说明。

    1. nonce

    想获取nonce,其实只需要调用eth_getTransactionCount就可以,这并不是一个随机数,而是记录了当前地址的交易次数,每交易一次,这个值会加1。
    由于以太坊TPS太低的缘故,经常会发生你发出交易后,很长时间一直处于pending状态,这时候一般有两种做法,加速和取消。
    所谓加速就是提高gasPrice,加速打包和交易进度,取消则是放弃该笔交易。
    但是不管是加速还是取消,最重要的就是传入和之前同样的nonce,加速只要保证其他参数和之前交易的参数相同(除gasPrice),而取消交易我的操作可能不是很正统,我是直接传入错误的参数使智能合约报错来取消交易。

    2. gas

    关于以太坊的gas,又可以写一篇文章来说明的,我个人对此也是又爱又恨,感觉在做以太坊开发,有时候和使用云服务上提供的无服务函数功能一样,按CPU、内存等占用情况来付费。发展到EOS更为明显。
    新手经常被gas的问题牵绊,这里我只想说明,很多情况下,只需要设置gasPrice即可,而且想让交易更快运行,也是调高gasPricegasPrice越高,交易所花费的手续费越多。
    至于gasPrice要设置多少,这里可又得说一阵。
    以太坊提供一个函数eth_gasPrice,在代理API中也有此函数,可以获取当前安全的gasPrice,但是依靠这个值绝对不行,我们的交易就经常发生卡住3-5个小时还未打包。
    到底设置多少其实没有一个标准,有时候设置20gwei都闲不够,但有时候设置1gwei同样可以快速完成交易,手续费相差足足有几十倍之多。
    业界现行的做法也只是预测,根据最近几百个区块的交易情况来估算现在以太坊的拥堵程度,以得出一个预测的数值,我这里直接使用https://www.etherchain.org/tools/gasPriceOracle提供的API接口。

    3. chainId

    参考https://github.com/ethereum/EIPs/blob/master/EIPS/eip-155.md

    4. data

    在调用智能合约时,需要指定调用的方法和参数,这里在上一篇文章中已经提到了,这里着重说明。
    比如你要做一个可增发的ERC20代币,需要有增发的方法:

    function mint(
        address _to,
        uint256 _amount
      )
        hasMintPermission
        canMint
        public
        returns (bool)
      {
        totalSupply_ = totalSupply_.add(_amount);
        balances[_to] = balances[_to].add(_amount);
        emit Mint(_to, _amount);
        emit Transfer(address(0), _to, _amount);
        return true;
      }
    

    调用方法本来是这样mint('0xcbec8ec09f94c80852e85693547f72b99ea2f327', 1000000000),但是由于跨语言,跨环境,势必而言需要有一套规范或编码,比如银行的8583报文一般。

    1. 方法名和参数类型做sha3,然后截取前十位:substr(sha3('mint(address,uint256)', 0, 10)
    2. address和uint256分别转成16进制,然后补足64位
    3. 拼接三个参数

    使用PHP开发以太坊代币和合约这个系列准备暂时写到这里,主要介绍了我的开源项目https://github.com/NanQi/ethereum-php
    ,但是具体的代币和合约开发这里还没有提及,准备接下来会以做一款资金盘传销币的项目来继续说明,敬请期待。个人QQ:二七5零9六96七

    相关文章

      网友评论

        本文标题:使用PHP开发以太坊代币与合约——以太坊交易

        本文链接:https://www.haomeiwen.com/subject/gbtpectx.html