`

使用PHP生成以太坊钱包和密钥对

阅读更多

本文将提供有关如何生成ECDSA私钥的指南,然后使用PHP7.0++导出到以太坊钱包地址。

你可以找到以下工作实现:

composer.json

{
    "require": {
        "sop/asn1": "^3.3",
        "sop/crypto-encoding": "^0.2.0",
        "sop/crypto-types": "^0.2.1",
        "kornrunner/keccak": "^1.0",
        "symfony/dotenv": "^4.0",
        "sc0vu/web3.php": "dev-master"
    }
}

GenerateEthereumWallet.php

<?php
require_once "vendor/autoload.php";
use Sop\CryptoTypes\Asymmetric\EC\ECPublicKey;
use Sop\CryptoTypes\Asymmetric\EC\ECPrivateKey;
use Sop\CryptoEncoding\PEM;
use kornrunner\keccak;
$config = [
    'private_key_type' => OPENSSL_KEYTYPE_EC,
    'curve_name' => 'secp256k1'
];
$res = openssl_pkey_new($config);
if (!$res) {
    echo 'ERROR: Fail to generate private key. -> ' . openssl_error_string();
    exit;
}
// 生成私钥
openssl_pkey_export($res, $priv_key);
// 获取公钥
$key_detail = openssl_pkey_get_details($res);
$pub_key = $key_detail["key"];
$priv_pem = PEM::fromString($priv_key);
// 转换为椭圆曲线私钥格式
$ec_priv_key = ECPrivateKey::fromPEM($priv_pem);
// 然后将其转换为ASN1结构
$ec_priv_seq = $ec_priv_key->toASN1();
// HEX中的私钥和公钥
$priv_key_hex = bin2hex($ec_priv_seq->at(1)->asOctetString()->string());
$priv_key_len = strlen($priv_key_hex) / 2;
$pub_key_hex = bin2hex($ec_priv_seq->at(3)->asTagged()->asExplicit()->asBitString()->string());
$pub_key_len = strlen($pub_key_hex) / 2;
// 从公钥导出以太坊地址
// 每个EC公钥始终以0x04开头,
// 我们需要删除前导0x04才能正确hash它
$pub_key_hex_2 = substr($pub_key_hex, 2);
$pub_key_len_2 = strlen($pub_key_hex_2) / 2;
// Hash
$hash = Keccak::hash(hex2bin($pub_key_hex_2), 256);
// 以太坊地址长度为20个字节。 (40个十六进制字符长)
// 我们只需要最后20个字节作为以太坊地址
$wallet_address = '0x' . substr($hash, -40);
$wallet_private_key = '0x' . $priv_key_hex;
echo "\r\n   ETH Wallet Address: " . $wallet_address;
echo "\r\n   Private Key: " . $wallet_private_key;

代码条件

该代码需要PHP 7.0++,OpenSSL扩展和PHP Composer。需要使用PHP Composer来安装第三方软件包。

$ composer install

生成私钥

以太坊标准是使用secp256k1曲线生成私钥。在我的教程中,我使用OpenSSL函数生成PEM格式的椭圆曲线私钥,如下所示:

$config = [
    'private_key_type' => OPENSSL_KEYTYPE_EC,
    'curve_name' => 'secp256k1'
];
$res = openssl_pkey_new($config);
if (!$res) {
    echo 'ERROR: Fail to generate private key. -> ' . openssl_error_string();
    exit;
}
// Generate Private Key
openssl_pkey_export($res, $priv_key);
// PEM Format
$priv_pem = PEM::fromString($priv_key);

之后我需要将私钥转换为ASN1序列,下面是ANS1序列的结构。

ECPrivateKey ::= SEQUENCE {
    version        INTEGER { ecPrivkeyVer1(1) } (ecPrivkeyVer1),
    privateKey     OCTET STRING,
    parameters [0] ECParameters {{ NamedCurve }} OPTIONAL,
    publicKey  [1] BIT STRING OPTIONAL
}

下面的代码是我如何从ANS1序列结构中查询十六进制字符串中的公钥和私钥。

// Then convert it to ASN1 Structure
$ec_priv_seq = $ec_priv_key->toASN1();
// Private Key & Public Key in HEX
$priv_key_hex = bin2hex($ec_priv_seq->at(1)->asOctetString()->string());
$priv_key_len = strlen($priv_key_hex) / 2;
$pub_key_hex = bin2hex($ec_priv_seq->at(3)->asTagged()->asExplicit()->asBitString()->string());
$pub_key_len = strlen($pub_key_hex) / 2;

衍生以太坊钱包地址

以太坊钱包地址来自公钥。每个EC公钥始终以0x04开头。为了获得以太坊钱包地址的正确哈希值,我们需要删除前导0x04。

$pub_key_hex_2 = substr($pub_key_hex, 2);
$pub_key_len_2 = strlen($pub_key_hex_2) / 2;

我们继续使用EC公钥的Keccak256哈希。 以太坊钱包地址长度为20个字节,长度为40个字符,因此我们只需要哈希数据的最后20个字节。

$hash = Keccak::hash(hex2bin($pub_key_hex_2), 256);
$wallet_address = '0x' . substr($hash, -40);
$wallet_private_key = '0x' . $priv_key_hex;

现在你有**$wallter_address存储你新生成的以太坊钱包地址,$wallet_private_key**是你以太坊钱包地址的私钥。

如何运行代码

$ php GenerateEthereumWallet.php

它将输出以太坊钱包地址及其私钥,如下所示:

ETH Wallet Address: 0xb2...
Private Key: 0x73...

======================================================================

分享一些以太坊、EOS、比特币等区块链相关的交互式在线编程实战教程:

php以太坊,主要是介绍使用php进行智能合约开发交互,进行账号创建、交易、转账、代币开发以及过滤器和交易等内容。

  • php比特币开发教程,本课程面向初学者,内容即涵盖比特币的核心概念,例如区块链存储、去中心化共识机制、密钥与脚本、交易与UTXO等,同时也详细讲解如何在Php代码中集成比特币支持功能,例如创建地址、管理钱包、构造裸交易等,是Php工程师不可多得的比特币开发学习课程。

汇智网原创翻译,转载请标明出处。这里是原文

0
0
分享到:
评论

相关推荐

    web3.php操作以太坊

    在本文中,我们将深入探讨如何使用`web3.php`库来操作以太坊私链,特别是在PHP环境中。`web3.php`是Web3.js的PHP版本,它为以太坊区块链提供了一个完整的API,使开发者能够与以太坊网络进行交互。 首先,`web3.php`...

    php web3操作以太坊

    在本文中,我们将深入探讨如何使用PHP Web3库来与以太坊区块链进行交互。以太坊是一个开源、公共的区块链平台,它支持智能合约功能,而Web3.js是JavaScript库,为以太坊提供了丰富的API接口。在PHP中,我们可以使用...

    区块链认证:使用以太坊区块链生成和验证证书

    使用区块链的证书生成和验证 使用以太坊在本地区块链设置上构建并部署在Rinkeby测试网络上。 合同部署在0x89c34c6a0d4c7587e9120a533757f380f4676887 RPC网络Rinkeby测试网络建立本地开发环境的步骤设置本地区块链...

    RSA密钥生成、 JS加密、PHP解密Demo

    - keygen.php:用于生成RSA密钥对的PHP脚本。 - encrypt.js:包含JavaScript加密函数的文件。 - decrypt.php:处理服务器端解密的PHP脚本。 - example.txt:示例明文文件。 - encrypted.txt:加密后的密文文件。 - ...

    PHP环境下php-web3-使用手册PHPWeb3连接以太坊网络

    PHP Web3 是一种在PHP环境下使用Ethereum区块链开发智能合约和与以太坊网络进行交互的工具库。它提供了方便易用的API接口,使开发人员可以快速地构建和部署智能合约以及进行区块链操作。本文将介绍如何使用PHP Web3...

    以太坊开发环境搭建

    以太坊开发环境搭建

    PHP与以太坊交互详解

    而PHP作为广泛应用的服务器端脚本语言,可以用来与以太坊进行交互,实现对以太坊网络的操作。这篇文章将深入探讨如何利用PHP与以太坊进行通信。 1. **开发环境搭建** 要在PHP环境中与以太坊交互,首先需要设置一个...

    10个优化以太坊智能合约gas利用的solidity代码模式

    本文将介绍在使用Solidity开发以太坊智能合约时常用的一些Gas优化模式。 以太坊教程链接: Dapp入门 | 电商Dapp实战 | Token实战 | Php对接 | Java对接 | Python对接 | C#对接 | Dart对接 1、使用短路模式排序...

    php生成秘钥和公钥,以及秘钥和公钥签名验证

    在PHP中,加密和安全通信通常涉及到密钥对的生成,包括私钥(秘钥)和公钥。OpenSSL库是PHP中用于处理这些任务的关键工具。本文将深入讲解如何使用PHP的OpenSSL扩展来创建密钥对,并利用它们进行数字签名的验证。 ...

    ethereum-php:PHP的以太坊客户端

    适用于PHP的以太坊客户端 PHP版本以太坊JSON RPC客户端。 可通过简单的添加合约地址和ABI来方便的调用合约内部的方法,对于需要对交易签名的请求,客户端会自动完成。 支持对事件(日志)的监听,但需要通过计时器...

    RSA1024 RSA2048算法密匙生成器

    这个jar文件可能是为了在Java环境中使用OpenSSL的命令行工具,如生成RSA密钥对、进行加密解密等操作。 `使用说明文档(请先阅读再操作).txt`是提供如何使用这些工具的指南,强烈建议在操作前仔细阅读,以避免误操作...

    php生成PDF电子合同签名

    总的来说,"php生成PDF电子合同签名"是一个融合了PHP编程、PDF处理、安全认证和电子签名法律知识的综合性任务。通过熟练运用FPDI和FPDF库,我们可以创建出功能完备、安全可靠的电子合同签署系统,极大地提高了业务...

    PHP泛目录生成源码 可生成新闻页面和关键词页面 带使用方法视频教程

    PHP泛目录生成源码 可生成新闻页面和关键词页面 带使用方法视频教程 泛目录可以用来提升网站收录和排名 合理运用目录可以达到快速出词和出权重的效果 程序小 基本的服务器都带的得动 带使用方法视频教程,站长未测,...

    支付宝RAS密钥生成器

    这个“支付宝RAS密钥生成器”工具可能是专门为PHP开发者设计的,帮助他们快速、便捷地创建和管理用于支付宝接口调用的RSA密钥对。 使用这个工具,开发者可以生成一对密钥,将公钥上传到支付宝平台,用于对请求参数...

    PHP把文字生成图片的简单例子

    本文将深入探讨如何使用PHP将文字转化为图片,这在验证码生成、动态标语制作或者自定义图形报告等领域都有广泛的应用。 首先,我们来看标题提到的"PHP把文字生成图片的简单例子"。这个例子的核心是利用PHP的GD库或...

    php二维码生成 包括名片生成

    PHP作为一款流行的服务器端脚本语言,也有许多库和方法可以实现二维码的生成。本文将深入探讨PHP二维码生成的相关知识点,特别是如何利用PHP创建包含名片信息的二维码。 1. **PHP二维码生成原理** PHP生成二维码的...

    phpWord,php生成word文档,替换word内容重新生成

    为了提高性能和用户体验,还可以考虑使用服务器上的缓存存储生成的文档,而不是每次请求时都重新生成。此外,如果学生信息量很大,可以考虑分页处理,避免一次性生成过大的文档。 总的来说,`phpWord`是一个功能...

    ThinkPHP整合phpqrcode生成二维码DEMO

    在IT行业中,生成二维码是一种常见的数据编码方式,它能够将大量信息浓缩成一个小型的图形,便于手机扫描和数据传输。本示例是关于如何在ThinkPHP框架中整合phpqrcode库来生成二维码的DEMO。这个过程涉及到前端与...

    PHP基于密钥的加密解密函数

    - `openssl_decrypt()`: 对应的解密函数,它使用相同的密钥和参数(除了密文)来恢复原始数据。 4. **加密算法** - PHP支持多种加密算法,如AES(高级加密标准)、DES、3DES等。AES是一种广泛应用的对称加密算法...

Global site tag (gtag.js) - Google Analytics