php怎么创建以太坊钱包地址,如何使⽤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
require_once "vendor/autoload.php";
use Sop\CryptoTypes\Asymmetric\EC\ECPublicKey;
use Sop\CryptoTypes\Asymmetric\EC\ECPrivateKey;
use Sop\CryptoEncoding\PEM;
php初学者项目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:
Private Key:
======================================================================
分享⼀些以太坊、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⼯程师不可多得的⽐特币开发学习课程。
汇智⽹原创翻译,转载请标明出处。这⾥是原⽂
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。
发表评论