内容简介:重复使用相同的比特币钱包地址是一个很大的隐私问题。如果你有一个简单的电子商店或要求捐赠的网站,你可能需要考虑为每笔交易生成唯一的地址。有很多支付系统,如Bitpay,为你完成所有艰苦的工作。缺点是他们需要使用你的私钥。但是,你可以使用来自分级确定性(hierarchically deterministic,简称HD)钱包的扩展公钥(XPUB)来实现你自己的简单解决方案。整个过程在
重复使用相同的比特币钱包地址是一个很大的隐私问题。如果你有一个简单的电子商店或要求捐赠的网站,你可能需要考虑为每笔交易生成唯一的地址。
有很多支付系统,如Bitpay,为你完成所有艰苦的工作。缺点是他们需要使用你的私钥。但是,你可以使用来自分级确定性(hierarchically deterministic,简称HD)钱包的扩展公钥(XPUB)来实现你自己的简单解决方案。
整个过程在 BIP32 中进行了解释。我建议你先阅读它,以便大致了解地址的来源。
在本教程中,我们将使用 Electrum
, OS X Sierra
, Apache 2.4
, PHP 7.1
和 Bit-Wasp/bitcoin-php
。
当谈到比特币钱包时,任何HD钱包(如Mycelium)都可以使用。在任何类UNIX系统上,特别是Linux,安装过程应该是相同的。
PHP库及其依赖项需要 PHP 5.6+。打开终端并检查你当前的版本:
php -v
在我的环境下,输出是:
PHP 7.1.0 (cli) (built: Jan 2 2017 20:09:35) ( NTS ) Copyright (c) 1997-2016 The PHP Group Zend Engine v3.1.0-dev, Copyright (c) 1998-2016 Zend Technologies
如果版本小于5.6,则必须先升级PHP。
全局安装Composer
在我们安装bitcoin-php库之前,我们需要确保安装了composer。
打开终端并输入:
composer -V
如果它的内容像这样: Composer version 1.3.0 2016-12-24 00:47:03
,你可以安全地跳过此步骤。
否则安装:
curl -sS https://getcomposer.org/installer | php sudo mv composer.phar /usr/local/bin/composer
再次运行 composer -V
检查它是否已成功安装。
安装比特币PHP库
转到你的Web服务器文档根目录(存储你网站的目录)并创建文件夹 bitcoin/hdkeys
。
在我的例子中,文档根目录是 ~/Sites
,但在其他类UNIX系统上也可能是 /var/www
。如果你不确定,检查你的服务器设置。
cd ~/Sites mkdir bitcoin bitcoin/hdkeys cd bitcoin/hdkeys
安装 Bit-Wasp/bitcoin-php
库:
composer require bitwasp/bitcoin
它将下载库和依赖项。此过程可能需要几分钟。
如果没有出任何错误,请转到下一步。
从xpub,ypux和zpub生成钱包地址
我写了一个小类,加载所有必要的bitcoin-php类并打包某些方法以方便使用。
将其下载到目录:
wget https://gist.githubusercontent.com/mariodian/5b67a1f315a74a7753a6f23d0198ec48/raw/2742a7909dd2621381de53209e85348a078df470/HD.php
首先,我们需要获得扩展的公钥。
打开Electrum,单击Wallet,然后单击Master Public Key并复制该字符串。
在Electrum 3.x中,转到 Wallet -> Information -> Master Public Key
。
Legacy address(p2pkh)
打开你喜欢的文本编辑器,创建一个名为generate.php的文件,然后复制并粘贴以下代码:
<?php require_once('./HD.php'); $xpub = 'xpub661MyMwAqRbcGYcu6n1FmV1TbE8EwnSKecRZLvKAMyj4qLf15qXsoNryiKNvCkRq3z5kBCeZG8115jj28eVqmeKBJZPqjAfwRD3TGx1w5hY'; $path = '0/0'; // 1st receiving address // $path = '0/2'; // 3rd receiving address // $path = '1/0'; // 1st change address // $path = '1/1'; // 2nd change address $hd = new HD(); $hd->set_xpub($xpub); $address = $hd->address_from_master_pub($path); echo $address;
确保根据你自己的密钥编辑 $xpub
变量(也可以使用我的)。
打开浏览器并输入 http//localhost/hdkeys/generate.php
(或你自己的路径)。
输出应与你的Electrum钱包中的第一个地址相同。
通过注释或者取消注释来查看代码中的不同路径的地址是否更改了。
如果你使用Mycelium,你必须编辑下 $path
变量:
$path = "44'/0'/0'/0/0";
这将显示第一个钱包地址。要增加地址索引,请编辑最后一位数字。
原生SegWit地址(p2wpkh)
对于以 bc1...
开头的原生SegWit地址(p2wkh),请使用以下代码:
<?php require_once('./HD.php'); $zpub = 'zpub.........'; $path = '0/0'; // 1st receiving address $hd = new HD(); $hd->set_zpub($zpub); $address = $hd->address_from_master_pub($path); echo $address;
不要忘记编辑 $zpub
变量。
非原生SegWit地址(p2sh-p2wpkh)
大多数SegWit钱包目前使用包含在p2sh中的pay-to-witness-public-key-hash地址。
示例代码为:
<?php require_once('./HD.php'); $ypub = 'ypub.........'; $path = '0/0'; // 1st receiving address $hd = new HD(); $hd->set_ypub($ypub); $address = $hd->address_from_master_pub($path); echo $address;
再次,更改自己的 $ypub
变量。
多重签名地址(p2sh)
在下一个例子中,我在Electrum中创建了一个2-of-2多重签名钱包。
这意味着签署和广播交易需要2个签名(总共2个)。第二个签名是从前一个示例的扩展密钥创建的。
如果你正在努力创建钱包,请参阅 Electrum文档 。
返回文本编辑器,创建一个名为 generate_multisig.php
的新文件,然后复制并粘贴以下内容:
<?php require_once('./HD.php'); $xpubs = array( 'xpub661MyMwAqRbcGgbfj3mCXkHkx4VUTrvTQQH19ehsU3gEgvSu2MrSwSuvRw8hWAQNdTuG9zYbbXZVP3Er1zpaicGpbJXUptZSsyaLQVD44BW', 'xpub661MyMwAqRbcGYcu6n1FmV1TbE8EwnSKecRZLvKAMyj4qLf15qXsoNryiKNvCkRq3z5kBCeZG8115jj28eVqmeKBJZPqjAfwRD3TGx1w5hY' ); $m = 2; // how many signatures are needed $path = '0/0'; // 1st receiving address // $path = '0/2'; // 3rd receiving address // $path = '1/0'; // 1st change address // $path = '0/1'; // 2nd change address $hd = new HD(); $hd->set_multisig_xpubs($xpubs); $address = $hd->multisig_address_from_xpub($m, $path); echo $address;
再次,相应地编辑 $xpubs
或使用我的密钥。如果你使用其他钱包,请不要忘记更改 $path
。
在浏览器中打开 http://localhost/hdkeys/generate_multisig.php
,你应该会看到第一个多签名钱包地址。
如何使用代码
每次收到新订单时,从数据库中获取最后一个地址索引,递增它并生成新地址。
使用新订单保存新的钱包地址,时间戳和索引。
你还可以检查周那几天内未获得资助的现有地址有哪些。如果找到此类地址,则可以将其分配给新订单。
这样可以防止生成太多地址。
但是,如果你确实生成了大量地址,则需要提高钱包的 gap limit
。
转到Electrum控制台并运行以下命令并重新启动钱包:
wallet.gap_limit = 100
当你转到地址选项卡时,你应该会看到更多钱包(以红色突出显示)。
正如你所看到的,整个解决方案只是几行代码,主要优点是与你的私钥保持一致。你不依赖任何第三方,这是主要目的。希望这个教程很有用,如果遇到任何问题,请告诉我。
分享一些以太坊、EOS、比特币等区块链相关的交互式在线编程实战教程:
- java以太坊开发教程,主要是针对 java 和android程序员进行区块链以太坊开发的web3j详解。
- python以太坊,主要是针对 python 工程师使用web3.py进行区块链以太坊开发的详解。
- php以太坊,主要是介绍使用php进行智能合约开发交互,进行账号创建、交易、转账、代币开发以及过滤器和交易等内容。
- 以太坊入门教程,主要介绍智能合约与dapp应用开发,适合入门。
- 以太坊开发进阶教程,主要是介绍使用node.js、 mongodb 、区块链、ipfs实现去中心化电商DApp实战,适合进阶。
- C#以太坊,主要讲解如何使用C#开发基于.Net的以太坊应用,包括账户管理、状态与交易、智能合约开发与交互、过滤器和交易等。
- EOS教程,本课程帮助你快速入门EOS区块链去中心化应用的开发,内容涵盖EOS工具链、账户与钱包、发行代币、智能合约开发与部署、使用代码与智能合约交互等核心知识点,最后综合运用各知识点完成一个便签DApp的开发。
- java比特币开发教程,本课程面向初学者,内容即涵盖比特币的核心概念,例如区块链存储、去中心化共识机制、密钥与脚本、交易与UTXO等,同时也详细讲解如何在Java代码中集成比特币支持功能,例如创建地址、管理钱包、构造裸交易等,是Java工程师不可多得的比特币开发学习课程。
- php比特币开发教程,本课程面向初学者,内容即涵盖比特币的核心概念,例如区块链存储、去中心化共识机制、密钥与脚本、交易与UTXO等,同时也详细讲解如何在Php代码中集成比特币支持功能,例如创建地址、管理钱包、构造裸交易等,是Php工程师不可多得的比特币开发学习课程。
- tendermint区块链开发详解 ,本课程适合希望使用tendermint进行区块链开发的工程师,课程内容即包括tendermint应用开发模型中的核心概念,例如ABCI接口、默克尔树、多版本状态库等,也包括代币发行等丰富的实操代码,是 go 语言工程师快速入门区块链开发的最佳选择。
汇智网原创翻译,转载请标明出处。这里是原文 使用PHP从扩展公钥生成比特币钱包地址
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持 码农网
猜你喜欢:- 学习 btc 钱包私钥、公钥和地址的生成过程
- 从0到1学习区块链–私钥、公钥、钱包地址的含义
- bitcoin:压缩公钥与未压缩公钥
- [学习笔记] “付款到公钥” 和 “付款到公钥哈希”
- Golang代码搜集-基于RSA的公钥加密私钥解密-私钥签名公钥验证
- 随处可见的公钥证书
本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们。
C#图解教程
索利斯 (Daniel M.Solis) / 姚琪琳、苏林、朱晔 / 人民邮电出版社 / 2013-7-1 / CNY 89.00
本书是广受赞誉的C# 图解教程的最新版本。作者在本书中创造了一种全新的可视化叙述方式,以图文并茂的形式、朴实简洁的文字,并辅以大量表格和代码示例,全面、直观地阐述了C# 语言的各种特性。新版本除了精心修订旧版内容外,还全面涵盖了C# 5.0 的新增特性,比如异步编程、调用者信息、case 表达式、带参数的泛型构造函数、支持null 类型运算等。通过本书,读者能够快速、深入理解C#,为自己的编程生涯......一起来看看 《C#图解教程》 这本书的介绍吧!
html转js在线工具
html转js在线工具
HEX HSV 转换工具
HEX HSV 互换工具