摘要:重復使用相同的比特幣錢包地址是一個很大的隱私問題。安裝比特幣庫轉到你的服務器文檔根目錄存儲你網站的目錄并創建文件夾。如果你使用,你必須編輯下變量這將顯示第一個錢包地址。這里是原文使用從擴展公鑰生成比特幣錢包地址
重復使用相同的比特幣錢包地址是一個很大的隱私問題。如果你有一個簡單的電子商店或要求捐贈的網站,你可能需要考慮為每筆交易生成唯一的地址。
有很多支付系統,如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庫及其依賴項需要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
它將下載庫和依賴項。此過程可能需要幾分鐘。
如果沒有出任何錯誤,請轉到下一步。
從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的文件,然后復制并粘貼以下代碼:
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),請使用以下代碼:
set_zpub($zpub); $address = $hd->address_from_master_pub($path); echo $address;
不要忘記編輯$zpub變量。
非原生SegWit地址(p2sh-p2wpkh)大多數SegWit錢包目前使用包含在p2sh中的pay-to-witness-public-key-hash地址。
示例代碼為:
set_ypub($ypub); $address = $hd->address_from_master_pub($path); echo $address;
再次,更改自己的$ypub變量。
多重簽名地址(p2sh)在下一個例子中,我在Electrum中創建了一個2-of-2多重簽名錢包。
這意味著簽署和廣播交易需要2個簽名(總共2個)。第二個簽名是從前一個示例的擴展密鑰創建的。
如果你正在努力創建錢包,請參閱Electrum文檔。
返回文本編輯器,創建一個名為generate_multisig.php的新文件,然后復制并粘貼以下內容:
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從擴展公鑰生成比特幣錢包地址
文章版權歸作者所有,未經允許請勿轉載,若此文章存在違規行為,您可以聯系管理員刪除。
轉載請注明本文地址:http://specialneedsforspecialkids.com/yun/29627.html
摘要:重復使用相同的比特幣錢包地址是一個很大的隱私問題。安裝比特幣庫轉到你的服務器文檔根目錄存儲你網站的目錄并創建文件夾。如果你使用,你必須編輯下變量這將顯示第一個錢包地址。這里是原文使用從擴展公鑰生成比特幣錢包地址 重復使用相同的比特幣錢包地址是一個很大的隱私問題。如果你有一個簡單的電子商店或要求捐贈的網站,你可能需要考慮為每筆交易生成唯一的地址。 有很多支付系統,如Bitpay,為你完成...
摘要:公鑰上面生成的密鑰的公共部分被編碼為比特幣地址。使用對地址進行編碼我們現在使用庫中的方法來獲得最終的比特幣地址。這是比特幣應在交易中發送到的地址。這是一個如何在中生成比特幣地址的演示文稿。 讓我們通過學習比特幣(Bitcoin)如何實施該技術的各個方面來工作,好嗎?該技術包括以下幾個方面: 比特幣地址bitcoin address是用來發送和接收比特幣的。 交易transaction...
摘要:公鑰上面生成的密鑰的公共部分被編碼為比特幣地址。使用對地址進行編碼我們現在使用庫中的方法來獲得最終的比特幣地址。這是比特幣應在交易中發送到的地址。這是一個如何在中生成比特幣地址的演示文稿。 讓我們通過學習比特幣(Bitcoin)如何實施該技術的各個方面來工作,好嗎?該技術包括以下幾個方面: 比特幣地址bitcoin address是用來發送和接收比特幣的。 交易transaction...
摘要:本文首發于深入淺出區塊鏈社區原文鏈接理解開發錢包涉及的原文已更新,請讀者前往原文閱讀如果你還在被錢包搞的一頭霧水,來看看這邊文章吧。所以我們要開發以太坊錢包同樣需要對比特幣的錢包提案有所了解。 本文首發于深入淺出區塊鏈社區原文鏈接:理解開發HD錢包涉及的BIP32、BIP44、BIP39原文已更新,請讀者前往原文閱讀 如果你還在被HD錢包、BIP32、BIP44、BIP39搞的一頭霧水...
摘要:本文首發于深入淺出區塊鏈社區原文鏈接理解開發錢包涉及的原文已更新,請讀者前往原文閱讀如果你還在被錢包搞的一頭霧水,來看看這邊文章吧。所以我們要開發以太坊錢包同樣需要對比特幣的錢包提案有所了解。 本文首發于深入淺出區塊鏈社區原文鏈接:理解開發HD錢包涉及的BIP32、BIP44、BIP39原文已更新,請讀者前往原文閱讀 如果你還在被HD錢包、BIP32、BIP44、BIP39搞的一頭霧水...
閱讀 888·2021-09-22 15:17
閱讀 1917·2021-09-22 15:06
閱讀 2211·2021-09-08 09:35
閱讀 5099·2021-09-01 11:43
閱讀 3476·2019-08-30 15:55
閱讀 2150·2019-08-30 12:48
閱讀 3150·2019-08-30 12:45
閱讀 1782·2019-08-29 17:31