如何使用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工程师不可多得的比特币开发学习课程。
- python以太坊,主要是针对python工程师使用web3.py进行区块链以太坊开发的详解。
- java以太坊开发教程,主要是针对java和android程序员进行区块链以太坊开发的web3j详解。
- 以太坊入门教程,主要介绍智能合约与dapp应用开发,适合入门。
- 以太坊开发进阶教程,主要是介绍使用node.js、mongodb、区块链、ipfs实现去中心化电商DApp实战,适合进阶。
- C#以太坊,主要讲解如何使用C#开发基于.Net的以太坊应用,包括账户管理、状态与交易、智能合约开发与交互、过滤器和交易等。
- EOS教程,本课程帮助你快速入门EOS区块链去中心化应用的开发,内容涵盖EOS工具链、账户与钱包、发行代币、智能合约开发与部署、使用代码与智能合约交互等核心知识点,最后综合运用各知识点完成一个便签DApp的开发。
- java比特币开发教程,本课程面向初学者,内容即涵盖比特币的核心概念,例如区块链存储、去中心化共识机制、密钥与脚本、交易与UTXO等,同时也详细讲解如何在Java代码中集成比特币支持功能,例如创建地址、管理钱包、构造裸交易等,是Java工程师不可多得的比特币开发学习课程。
汇智网原创翻译,转载请标明出处。这里是原文