PHP扩展公钥生成比特币钱包地址

重复使用相同的比特币钱包地址是一个很大的隐私问题。如果你有一个简单的电子商店或要求捐赠的网站,你可能需要考虑为每笔交易生成唯一的地址。

有很多支付系统,如Bitpay,为你完成所有艰苦的工作。缺点是他们需要使用你的私钥。但是,你可以使用来自分级确定性(hierarchically deterministic,简称HD)钱包的扩展公钥(XPUB)来实现你自己的简单解决方案。

整个过程在BIP32中进行了解释。我建议你先阅读它,以便大致了解地址的来源。

在本教程中,我们将使用ElectrumOS X SierraApache 2.4PHP 7.1Bit-Wasp/bitcoin-php

当谈到比特币钱包时,任何HD钱包(如Mycelium)都可以使用。在任何类UNIX系统上,特别是Linux,安装过程应该是相同的。

PHP库及其依赖项需要PHP5.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 

它将下载库和依赖项。此过程可能需要几分钟。

image

如果没有出任何错误,请转到下一步。

从xpub,ypux和zpub生成钱包地址

我写了一个小类,加载所有必要的bitcoin-php类并打包某些方法以方便使用。

将其下载到目录:

wget https://gist.githubusercontent.com/mariodian/5b67a1f315a74a7753a6f23d0198ec48/raw/2742a7909dd2621381de53209e85348a078df470/HD.php

首先,我们需要获得扩展的公钥。

打开Electrum,单击Wallet,然后单击Master Public Key并复制该字符串。

image

在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(或你自己的路径)。

image

输出应与你的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,你应该会看到第一个多签名钱包地址。

image

如何使用代码

每次收到新订单时,从数据库中获取最后一个地址索引,递增它并生成新地址。

使用新订单保存新的钱包地址,时间戳和索引。

你还可以检查周那几天内未获得资助的现有地址有哪些。如果找到此类地址,则可以将其分配给新订单。

这样可以防止生成太多地址。

但是,如果你确实生成了大量地址,则需要提高钱包的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从扩展公钥生成比特币钱包地址

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 213,254评论 6 492
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 90,875评论 3 387
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 158,682评论 0 348
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 56,896评论 1 285
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,015评论 6 385
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,152评论 1 291
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,208评论 3 412
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,962评论 0 268
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,388评论 1 304
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,700评论 2 327
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,867评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,551评论 4 335
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,186评论 3 317
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,901评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,142评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,689评论 2 362
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,757评论 2 351

推荐阅读更多精彩内容