使用PHP开发以太坊代币与合约——以太坊交易
$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
即可,而且想让交易更快运行,也是调高gasPrice
,gasPrice
越高,交易所花费的手续费越多。
至于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报文一般。
- 方法名和参数类型做sha3,然后截取前十位:
substr(sha3('mint(address,uint256)', 0, 10)
- address和uint256分别转成16进制,然后补足64位
- 拼接三个参数
使用PHP开发以太坊代币和合约这个系列准备暂时写到这里,主要介绍了我的开源项目https://github.com/NanQi/ethereum-php
,但是具体的代币和合约开发这里还没有提及,准备接下来会以做一款资金盘传销币的项目来继续说明,敬请期待。个人QQ:二七5零9六96七