虽然EOS的密钥算法相似于比特币,但作了一些调整,定义了本身的格式。开发包EosTool包含了EOS离线密钥生成模块,能够不链接任何节点实现离线生成EOS密钥。本文将给出EOS离线密钥生成的PHP代码示例。php
若是要学习EOS应用开发,能够访问这个 【EOS智能合约与DApp开发教程】,教程内容涵盖EOS工具链、帐户与钱包、代币发行、智能合约开发、部署与交互等核心知识点,最后综合运用各知识点完成一个便签DApp的开发。算法
使用PrivateKey类的静态方法new()
生成随机私钥。例如:工具
use EosTool\Crypto\PrivateKey; $prv = PrivateKey::new(); echo $prv->toEos() . PHP_EOL; //相似:5Hu6nxM6s6UQ3nYkr1s1GKA17zPqpceUuWxH3JBwK8ZorMSRqGi
toEos()
方法用来将私钥对象转换为EOS的自定义格式。学习
从私钥能够推导出公钥,例如:code
$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);