BtcTool是一個基於第三方服務和離線裸交易實現的PHP比特幣應用開發包,適合不但願部署本地 節點旳PHP開發者,開發包主要包含如下特性:php
BtcTool目前支持的第三方服務包括,而且能夠很是簡單進行擴展:json
BtcTool下載地址:http://sc.hubwiz.com/codebag/btc-php-lib/composer
BtcTool運行在**Php 7.1+**環境下,當前版本1.0.0,主要代碼文件清單以下:函數
碼文件 | 說明 |
---|---|
btctool/src/Wallet.php | 離線錢包類,開發包入口 |
btctool/src/Utxo.php | 未消費交易輸出類 |
btctool/src/UtxoBag.php | Utxo集合類 |
btctool/src/UtxoCollector.php | Utxo收集器接口 |
btctool/src/CloudUtxoCollector.php | 基於第三方服務的Utxo收集器實現 |
btctool/src/UtxoSelector.php | Utxo篩選器接口 |
btchtool/src/DefaultUtxoSelector.php | 默認的Utxo篩選器實現 |
btctool/src/Broadcaster.php | 交易廣播器接口 |
btctool/src/CloudBroadcaster.php | 基於第三方服務的交易廣播器實現 |
btctool/src/Utils.php | 經常使用輔助函數 |
demo/wallet-init.php | 本地錢包初始化 |
demo/wallet-demo.php | 錢包載入、裸交易構造和廣播 |
vendor | 第三方依賴包目錄 |
composer.json | composer配置文件 |
BtcTool的入口是Wallet類,基本的使用步驟以下:ui
示例例代碼以下,說明見註釋:編碼
<?php require('../vendor/autoload.php'); use BtcTool\Wallet; //引入開發包 $wallet = new Wallet('testnet'); //建立錢包,主網傳入 mainnet $prvKey = '...'; //向錢包中添加私鑰,可添加多個 $wallet->addKey($prvKey); $toAddr = 'mgYPLmNuZymK...e2XUNF6VFnT' //地址應當與testnet/mainnet保持一致 $amount = 10000; //單位:satoshi $rawtx = $wallet->sendTx($toAddr,$amount); //構造裸交易,返回16進制字符串 $ret = $wallet->broadcast($rawtx); //廣播裸交易
注意:code
$rawtx = $wallet->sendTx($toAddr,$amount,$changeAddr,$fee);
若是未指定後面兩個參數,找零地址默認爲錢包中第一個私鑰對應的地址,手續費默認爲10000satoshi(高費率)。 3. 轉帳目標地址應當與建立Wallet對象時指定的鏈ID一致,例如mainnet的p2pkh地址,前綴應當爲1對象
利用錢包地址列表,獲取候選UTXO。接口
接口方法:開發
當前實現類:
根據目標金額從候選UTXO中選擇可消費UTXO
接口方法:
當前實現類:
裸交易廣播器
接口方法:
當前實現類:
管理私鑰、地址和腳本,同時提供構造和廣播裸交易的方法
主要方法: