您的位置:首页 > 编程语言 > PHP开发

php实现以太坊助记词

2019-06-18 00:02 1356 查看

以太坊助记词PHP开发包用来为PHP以太坊应用增加助记词和层级确定密钥支持能力。下载地址:以太坊助记词php开发包

1、开发包概述

以太坊助记词PHP开发包主要包括以下特性:

  • 生成符合BIP39标准的助记词
  • 将BIP39助记词转换为符合BIP32标准的层级确定密钥
  • 支持BIP44多币种层级确定性钱包规范
  • 兼容imtoken、metamask等常见钱包的助记词与密钥/地址转换

以太坊助记词PHP开发包运行在Php 7.1+环境下,当前版本1.0.0,主要代码文件清单如下:

<table class="table table-striped">
<thead>
<tr><th>代码文件</th><th>说明</th></tr>
</thead>
<tbody>
<tr><td>ethtool/src/Mnemonic.php</td><td>助记词实现类</td></tr>
<tr><td>ethtool/src/WordListInterface.php</td><td>助记词典接口</td></tr>
<tr><td>ethtool/src/EnglishWordList.php</td><td>英语助记词典实现类</td></tr>
<tr><td>ethtool/src/HDKey.php</td><td>层级确定密钥实现类</td></tr>
<tr><td>ethtool/src/Utils.php</td><td>辅助工具类</td></tr>
<tr><td>demo/demo-mnemonic.php</td><td>助记词生成与导入演示代码</td></tr>
<tr><td>demo/demo-hkey.php</td><td>助记词结合层级确定密钥演示代码</td></tr>
<tr><td>vendor</td><td>第三方依赖包目录</td></tr>
<tr><td>composer.json</td><td>composer配置文件</td></tr>
</tbody>
</table>

软件包下载地址:http://sc.hubwiz.com/codebag/eth-mnemonic-lib/

2、核心类使用说明

Mnemonic类是以太坊助记词PHP开发包的入口类,用于生成符合BIP39标准的助记词,或者将已有的助记词转化为对应的随机熵值,以便用于私钥的生成。

Mnemonic类提供以下静态方法来进行实例化:

  • new():创建新的Mnemonic对象
  • fromWords():使用已有的助记词实例化Mnemonic对象
  • fromEntropy():使用已有的随机熵实例化Mnemonic对象

Mnemonic实例提供以下方法获取其表征的随机熵和助记词:

  • getEntropy():获取随机熵
  • getWords():获取助记词

HDKey类用来创建支持BIP32/BIP44标准的层级确定密钥,提供以下静态方法实例化:

  • fromMnemonic():使用助记词创建层级确定主密钥
  • fromSeed():使用种子数据创建层级确定主密钥

HDKey实例对象提供以下方法派生后代HDKey:

  • deriveChild():派生指定序号的子密钥
  • derivePath():派生指定层级路径的后代密钥

3、示例代码:生成新的助记词

下面的代码使用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->derive("m/44'/60'/0'/0/0");            /*生成BIP44约定的第一个以太坊密钥路径对应的层级密钥*/
echo 'private key => ' . $key0->privateKey . PHP_EOL;   /*显示层级密钥对应的私钥,16进制字符串*/
echo 'address => ' . $key0->address . PHP_EOL;          /*显示层级密钥对应的以太坊地址*/

4、示例代码:导入已有的助记词

下面的代码使用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->derive("m/44'/60'/0'/0/0");            /*生成BIP44约定的第一个以太坊密钥路径对应的层级密钥*/
echo 'private key => ' . $key0->privateKey . PHP_EOL;   /*显示层级密钥对应的私钥,16进制字符串*/
echo 'address => ' . $key0->address . PHP_EOL;          /*显示层级密钥对应的以太坊地址*/
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: