虽然EOS的密钥算法类似于比特币,但做了一些调整,定义了自己的格式。开发包EosTool包含了EOS离线密钥生成模块,可以不连接任何节点实现离线生成EOS密钥。本文将给出EOS离线密钥生成的PHP代码示例。
如果要学习EOS应用开发,可以访问这个 【EOS智能合约与DApp开发教程】,教程内容涵盖EOS工具链、账户与钱包、代币发行、智能合约开发、部署与交互等核心知识点,最后综合运用各知识点完成一个便签DApp的开发。
使用PrivateKey类的静态方法new()
生成随机私钥。例如:
use EosTool\Crypto\PrivateKey;
$prv = PrivateKey::new();
echo $prv->toEos() . PHP_EOL; //类似:5Hu6nxM6s6UQ3nYkr1s1GKA17zPqpceUuWxH3JBwK8ZorMSRqGi
toEos()
方法用来将私钥对象转换为EOS的自定义格式。
从私钥可以推导出公钥,例如:
$pub = $prv->getPublicKey();
echo $pub->toEos() . PHP_EOL; //类似:EOS6wQ6t3n148GfzLzgxq7cC8ARDKxeaB3hQXdXn7oZYdwEyAXiSv
同样,使用公钥对象的toEos()
方法将公钥转换为EOS的自定义格式。
可以将一个EOS格式的私钥转化为EosTool的PrivateKey对象,例如,下面的代码将指定的EOS私钥导入,并显示其对应的EOS公钥:
$prv = PrivateKey::fromEos('5Hu6nxM6s6UQ3nYkr1s1GKA17zPqpceUuWxH3JBwK8ZorMSRqGi');
echo $prv->getPublicKey()->toEos() . PHP_EOL;
PrivateKey的sign()
方法支持普通签名和EOS节点要求的权威签名。例如下面的代码返回一个 普通签名:
$hex = '1234567890abcdef...';
$signature = $prv->sign($hex);
通过传入额外的参数true
来获得指定数据的权威签名:
$hex = '1234567890abcdef...';
$signature = $prv->sign($hex,true);
来源:oschina
链接:https://my.oschina.net/u/2472105/blog/2989246