使用PHP开发以太坊代币与合约以太坊以太坊(ethereum)实现研究

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

2019-08-28  本文已影响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七

上一篇下一篇

猜你喜欢

热点阅读