在PHP以太坊应用中增加对BIP39助记词和BIP32/BIP44层级确定密钥的支持。
以太坊助记词PHP开发包用来为PHP以太坊应用增加助记词和层级确定密钥 支持能力,主要包括以下特性:
以太坊助记词PHP开发包运行在Php 7.1+环境下,当前版本1.0.0,主 要代码文件清单如下:
代码文件 | 说明 |
---|---|
ethtool/src/Mnemonic.php | 助记词实现类 |
ethtool/src/WordListInterface.php | 助记词典接口 |
ethtool/src/EnglishWordList.php | 英语助记词典实现类 |
ethtool/src/HDKey.php | 层级确定密钥实现类 |
ethtool/src/Utils.php | 辅助工具类 |
demo/demo-mnemonic.php | 助记词生成与导入演示代码 |
demo/demo-hkey.php | 助记词结合层级确定密钥演示代码 |
vendor | 第三方依赖包目录 |
composer.json | composer配置文件 |
Mnemonic类是以太坊助记词PHP开发包的入口类,用于生成符合BIP39标准的助记词, 或者将已有的助记词转化为对应的随机熵值,以便用于私钥的生成。
Mnemonic类提供以下静态方法来进行实例化:
Mnemonic实例提供以下方法获取其表征的随机熵和助记词:
HDKey类用来创建支持BIP32/BIP44标准的层级确定密钥,提供以下静态方法实例化:
HDKey实例对象提供以下方法派生后代HDKey:
下面的代码使用Mnemonic类的静态方法new()
生成新的助记词,然后输出显示
所生成的助记词及其对应的随机熵:
use EthTool\Mnemonic;
$mnemonic = Mnemonic::new(); /*创建新的助记词*/
echo 'mnemonic => ' . $mnemonic->getWords() . PHP_EOL; /*显示助记词*/
echo 'entropy => ' . $mnemonic->getEntropy() . PHP_EOL; /*显示对应的随机熵*/
使用助记词生成层级主密钥并按照BIP44约定生成层级确定钱包的 第一个以太坊密钥及地址:
$master = HDKey::fromMnemonic($mnemonic->getWords()); /*利用助记词生成BIP32层级主密钥*/
$key0 = $master->derivePath("m/44'/60'/0'/0/0"); /*生成BIP44约定的第一个以太坊密钥路径对应的层级密钥*/
echo 'private key => ' . $key0->privateKey . PHP_EOL; /*显示层级密钥对应的私钥,16进制字符串*/
echo 'address => ' . $key0->address . PHP_EOL; /*显示层级密钥对应的以太坊地址*/
下面的代码使用Menmonic类的静态方法fromWords()
导入已有的助记词,然后利用助记词
生成对应的层级密钥及BIP44以太坊钱包地址:
use EthTool\HDKey;
//助记词
$words = 'moral predict wash pledge hybrid box virtual length clap volcano shadow notice';
$master = HDKey::fromMnemonic($words); /*利用助记词生成BIP32层级主密钥*/
$key0 = $master->derivePath("m/44'/60'/0'/0/0"); /*生成BIP44约定的第一个以太坊密钥路径对应的层级密钥*/
echo 'private key => ' . $key0->privateKey . PHP_EOL; /*显示层级密钥对应的私钥,16进制字符串*/
echo 'address => ' . $key0->address . PHP_EOL; /*显示层级密钥对应的以太坊地址*/
本站所提供软件包仅用于学习和研究,请依法合规使用。
本站所提供软件包均提供完整源码,使用前请认真阅读源代码和文档以确保充分理解软件包的设计与功能实现,本站不承担 因不当使用本站所提供软件包而造成的任何法律风险或财产损失责任。