以太坊助记词PHP开发包简介
以太坊助记词PHP开发包用来为PHP以太坊应用增加助记词和层级确定密钥支持能力。下载地址:以太坊助记词php开发包 。
1、开发包概述
以太坊助记词PHP开发包主要包括以下特性:
- 生成符合BIP39标准的助记词
- 将BIP39助记词转换为符合BIP32标准的层级确定密钥
- 支持BIP44多币种层级确定性钱包规范
- 兼容imtoken、metamask等常见钱包的助记词与密钥/地址转换
以太坊助记词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配置文件 |
软件包下载地址: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; /*显示层级密钥对应的以太坊地址*/
低调大师中文资讯倾力打造互联网数据资讯、行业资源、电子商务、移动互联网、网络营销平台。
持续更新报道IT业界、互联网、市场资讯、驱动更新,是最及时权威的产业资讯及硬件资讯报道平台。
转载内容版权归作者及来源网站所有,本站原创内容转载请注明来源。
- 上一篇
十分钟上线 - 函数计算构建支付宝小程序的后端
阿里云函数计算服务(FunctionCompute,FC)是一个事件驱动的全托管计算服务。通过函数计算与云端各个服务的广泛集成,开发者只需要编写函数代码,就能够快速地开发出弹性高可用的后端系统。接下来我们使用FC,来快速实现一个图片转换服务, 并把这个图片转换服务作为支付宝小程序的后端。 支付宝小程序demo前端效果图: 资源下载及准备工作 示例代码附件 【必须】 支付宝小程序开发工具下载 【非必须】 函数计算FC 快捷入口对象存储OSS 快捷入口日志服务Log Service 快捷入口 简明架构图 函数入口 普通函数入口 def my_handler(event, context): return 'hello world' 函数名 my_handler需要与创建函数时的"Handler"字段相对应:例如创建函数时指定的 Handler 为m
- 下一篇
Flink实战(三) - 编程范式及核心概念
1 基本的 API 概念 Flink程序是实现分布式集合转换的常规程序(例如,过滤,映射,更新状态,加入,分组,定义窗口,聚合)。最初从源创建集合(例如,通过从文件,kafka主题或从本地的内存集合中读取)。结果通过接收器返回,接收器可以例如将数据写入(分布式)文件或标准输出(例如,命令行终端)。 Flink程序可以在各种环境中运行,独立运行或嵌入其他程序中。执行可以在本地JVM中执行,也可以在许多计算机的集群上执行。 根据数据源的类型,即有界或无界源,您可以编写批处理程序或流程序,其中 DataSet API用于批处理 DataStream API用于流式处理。 注意:在显示如何使用API的实际示例时,我们将使用StreamingExecutionEnvironment和DataStream API。 DataSet API中的概念完全相
相关文章
文章评论
共有0条评论来说两句吧...
文章二维码
点击排行
推荐阅读
最新文章
- Springboot2将连接池hikari替换为druid,体验最强大的数据库连接池
- CentOS6,CentOS7官方镜像安装Oracle11G
- Jdk安装(Linux,MacOS,Windows),包含三大操作系统的最全安装
- CentOS关闭SELinux安全模块
- CentOS7编译安装Gcc9.2.0,解决mysql等软件编译问题
- Windows10,CentOS7,CentOS8安装MongoDB4.0.16
- Hadoop3单机部署,实现最简伪集群
- SpringBoot2编写第一个Controller,响应你的http请求并返回结果
- Eclipse初始化配置,告别卡顿、闪退、编译时间过长
- SpringBoot2全家桶,快速入门学习开发网站教程