当前位置:主页 > 区块链 > 区块链技术 > bitcoin-php使用方法

Bit-Wasp/bitcoin-php 的简单使用:创建钱包 + 进行交易

2025-08-21 19:10:54 | 来源: | 作者:家猪配种专家
这里简单介绍了一下最最最基础的 Bit-Wasp/bitcoin-php 的用法,如果你对 bitcoin 还很陌生,推荐 【回形针 PaperClip】区块链到底是什么?

这里简单介绍了一下最最最基础的 Bit-Wasp/bitcoin-php 的用法,如果你对 bitcoin 还很陌生,推荐 【回形针 PaperClip】区块链到底是什么? 了解 bitcoin 和 比特币交易如何防伪?私钥公钥地址啥意思?李永乐老师讲比特币 (2) 大致了解 bitcoin 的交易流程。想进一步了解 bitcoin,推荐阅读 《精通比特币》。

项目依赖:

bitcoin-php bitcoin的php实现库,用于创建助记词和生成私钥 (此库需要运行在64位的php7.0+上)

ethereum-util 以太坊常用函数php实现库

1

2

composer require bitwasp/bitcoin

composer require web3p/ethereum-util

创建钱包

不同于中心化的钱包( 支付宝 / 微信 ),创建 Bitcoin 钱包不需要网络,只需要一个足够随机的数字 n ( 1 < n < 1.158 * 10^77 -1 , 略小于 2^256 ,关于这个数是否足够安全,可以看这个视频:256 位加密有多安全?),公钥和地址都是由这个 n 生成,它被称作 私钥

创建钱包本质上就是找到一个随机数。

但是你不能用 php 自带的随机数生成函数!!!因为 php 自带的这些随机数生成函数并不是密码学安全的随机数生成器(它是基于 unix 时间戳 /mac 地址 /etc 生成的数字,并不是真正的随机数)。

但是我们可以使用 Bit-Wasp/bitcoin-php 中密码学安全的随机数生成器生成一个随机数来作为我们的钱包:

在 Laravel Job 中的实现

 <?php
 namespace App\Jobs\Bitcoin;
 use Illuminate\Bus\Queueable;
 use Illuminate\Contracts\Queue\ShouldQueue;
 use Illuminate\Foundation\Bus\Dispatchable;
 use Illuminate\Queue\InteractsWithQueue;
 use Illuminate\Queue\SerializesModels;
 use App\Models\Bitcoin\Wallet;
 use BitWasp\Bitcoin\Address\PayToPubKeyHashAddress;
 use BitWasp\Bitcoin\Bitcoin;
 use BitWasp\Bitcoin\Crypto\Random\Random;
 use BitWasp\Bitcoin\Key\Factory\PrivateKeyFactory;
 class GenerateWallet implements ShouldQueue
 {
     use Dispatchable, InteractsWithQueue, Queueable, SerializesModels;
     /**
      * Execute the job.
      *
      * @return void
      */
     public function handle()
     {
         $random = new Random();
         $private_key_factory = new PrivateKeyFactory();
         $private_key = $private_key_factory->generateCompressed($random);
         $public_key = $private_key->getPublicKey();
         // p2pkh 格式的地址
         $address = new PayToPubKeyHashAddress($public_key->getPubKeyHash());
         // 将生成的钱包保存到数据库中
         $wallet = new Wallet;
         $wallet->wif = $private_key->toWif($network);
         $wallet->address = $address->getAddress();
         $wallet->save();
         // 保存到日志文件中
         $log  = "wif: ". $wallet->wif . PHP_EOL .
                 "address: ". $wallet->address . PHP_EOL .
                 "-------------". date('Y-m-d Hs') ."------------" . PHP_EOL;
         file_put_contents('./wallets.log', $log, FILE_APPEND);
     }
 }

下面就是我们创建的一个新钱包的示例:

wif 是一种私钥的格式,也是各个交易所、钱包所通用的私钥导入格式,原始的二进制数主要用于程序内部。

创建交易

我们首先来看一下一个已完成的交易有那些内容:

此标准交易的主要组成部分采用颜色编码:

交易 ID(以黄色突出显示)

描述符和元数据(蓝色花括号在右边详细说明)

输入(粉色区域)

输出(绿色区域)

我们要做的就是要离线构造一个如上的数据,在通过第三方或者你自己的结点广播出去,待区块确认后,即可视为完成了交易。
在这里需要注意以下几点:

交易信息里面,收款人的信息在输出里面,锁定脚本(scriptPubKey)将限制使用人,也就是地址所对的私钥。

交易时需要提供上次交易的 id,来证明你对 bitcoin 的所有权

bitcoin 的地址存在几种类型,这里暂不讨论,这里将根据提供的 p2pkh 地址发送到 p2wpkh 地址
在 Laravel Job 中的实现

<?php
namespace App\Jobs\Bitcoin;
use Illuminate\Bus\Queueable;
use Illuminate\Contracts\Queue\ShouldQueue;
use Illuminate\Foundation\Bus\Dispatchable;
use Illuminate\Queue\InteractsWithQueue;
use Illuminate\Queue\SerializesModels;
use BitWasp\Bitcoin\Address\PayToPubKeyHashAddress;
use BitWasp\Bitcoin\Bitcoin;
use BitWasp\Bitcoin\Key\Factory\PrivateKeyFactory;
use BitWasp\Bitcoin\Script\Interpreter\InterpreterInterface as I;
use BitWasp\Bitcoin\Script\ScriptFactory;
use BitWasp\Bitcoin\Transaction\Factory\Signer;
use BitWasp\Bitcoin\Transaction\Factory\TxBuilder;
use BitWasp\Bitcoin\Transaction\OutPoint;
use BitWasp\Bitcoin\Transaction\TransactionOutput;
use BitWasp\Buffertools\Buffer;
use BitWasp\Bitcoin\Transaction\Factory\SignData;
use BitWasp\Bitcoin\Script\WitnessScript;
use BitWasp\Bitcoin\Script\P2shScript;
use BitWasp\Bitcoin\Address\SegwitAddress;
use BitWasp\Bitcoin\Script\WitnessProgram;
use BitWasp\Bitcoin\Address\AddressCreator;
use GuzzleHttp\Client;
use GuzzleHttp\Exception\ClientException;
class Transfer implements ShouldQueue
{
 use Dispatchable, InteractsWithQueue, Queueable, SerializesModels;
 /**
  * Execute the job.
  *
  * @return void
  */
 public function handle()
 {
     // 支付钱包的私钥(wif 格式)
     $wif = 'KxwUMCtXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXxEGooz';
     // 支付钱包上一次交易的 id
     $txid = '4c7a031a31fe794e64ef5ca2714bdd9dd10ceae44650bce025952282bdeeda8b';
     // 收款钱包地址(p2pkh 格式)
     $address = '1LRqwmjqLNNybJ3M2zQHiwvyA6ikbQQkyS';
     $privKeyFactory = new PrivateKeyFactory;
     $key = $privKeyFactory->fromWif($wif);
     $witnessScript = new WitnessScript(
         ScriptFactory::scriptPubKey()->payToPubKeyHash($key->getPubKeyHash())
     );
     $dest = new SegwitAddress(
         WitnessProgram::v0(
             (new AddressCreator())->fromString($address)->getHash()
         )
     );
     // UTXO
     $outpoint = new OutPoint(Buffer::hex($txid, 32), 0);
     // 这里一共将支出 100000 聪(0.00000001 BTC = 1 聪)
     $txOut = new TransactionOutput(100000, $witnessScript);
     // 收款人将收到 90000 聪,中间的差将作为矿工的手续费
     $builder = (new TxBuilder())
         ->spendOutPoint($outpoint)
         ->payToAddress(90000, $dest);
     // 签署交易
     $signer = new Signer($builder->get(), Bitcoin::getEcAdapter());
     $input = $signer->input(0, $txOut);
     $input->sign($key);
     $signed = $signer->get();
     // 需要进行广播的交易
     $broadcast = $signed->getBaseSerialization()->getHex();
     // 我这里使用 blockchain.info 的接口进行广播,你可以使用你自己的结点,或者现成的 RPC 接口
     $client = new Client;
     try {
         $response = $client->request('POST', 'https://blockchain.info/pushtx', [
             'form_params' => [
                 'tx' => $signed->getBaseSerialization()->getHex()
             ]
         ]);
         var_dump(json_decode($response->getBody(), true));
     } catch (ClientException $e) {
         var_dump($e->getResponse());
     }
 }

成功进行广播你将收到:

待 10-15 分钟后,交易被写入区块,再等待后续生成 2-3 个区块,即可视为交易完成。
你可以在 Electrum 这样的开源钱包中查看你收到的钱

关于手续费:
你完全可以一毛不拔,一聪都不给,但是就没有矿工愿意打包你的交易,你的交易将永远无法完成。bitcoin 矿工的收入来自打包完成的系统奖励(到 2024 年就没有了)和该区块中的所有交易的手续费,所以矿工总是优先打包手续费多的交易。

免责声明:本文只为提供市场讯息,所有内容及观点仅供参考,不构成投资建议,不代表本站观点和立场。投资者应自行决策与交易,对投资者交易形成的直接或间接损失,作者及本站将不承担任何责任。!

你可能感兴趣的文章

更多

热门币种

  • 币名
    最新价格
    24H涨幅
  • bitcoin BTC 比特币

    BTC

    比特币

    $ 72922.79¥ 498099.11
    +1.23%
  • ethereum ETH 以太坊

    ETH

    以太坊

    $ 2242.04¥ 15314.25
    +1.83%
  • tether USDT 泰达币

    USDT

    泰达币

    $ 1.0003¥ 6.8325
    +0.02%
  • ripple XRP 瑞波币

    XRP

    瑞波币

    $ 1.3473¥ 9.2027
    +0.63%
  • binance-coin BNB 币安币

    BNB

    币安币

    $ 605.72¥ 4137.37
    +0.75%
  • usdc USDC USD Coin

    USDC

    USD Coin

    $ 0.9997¥ 6.8284
    -0.02%
  • solana SOL Solana

    SOL

    Solana

    $ 84.1127¥ 574.53
    +0.88%
  • tron TRX 波场

    TRX

    波场

    $ 0.3189¥ 2.1782
    -0.13%
  • dogecoin DOGE 狗狗币

    DOGE

    狗狗币

    $ 0.092883¥ 0.6344
    +0.58%
  • hyperliquid HYPE Hyperliquid

    HYPE

    Hyperliquid

    $ 42.2389¥ 288.51
    +3.06%

币圈快讯

  • Pyth推出数据市场PythDataMarketplace

    2026-04-11 20:02
    预言机服务Pyth宣布正式推出数据市场PythDataMarketplace并获得六家大型金融机构作为数据发布方支持,此次加入的机构包括Euronext、ExchangeDataInternational、FidelityInvestments、OTCMarketsGroup、SGX旗下FX数据业务,以Tradeweb,这些机构此前主要通过传统数据供应商和专有终端分发数据。PythDataMarketplace支持机构在保留数据所有权、定价权及署名权的前提下,分发包括宏观经济指标、场外交易(OTC)定价及外汇基准等各类专有数据。
  • 印尼外长:中巴五点倡议是促成永久停火的务实举措

    2026-04-11 20:00
    4月11日讯,印度尼西亚外交部长苏吉约诺日前接受采访时表示,中巴五点倡议是促进和平谈判、达成永久停火、加强平民保护和推动经济关系正常化的务实举措,印尼对此表示欢迎。苏吉约诺说,自美以伊冲突伊始,印尼就呼吁有关方面立即停止敌对行动并回到谈判桌前,努力通过符合国际法的方式解决问题。中巴五点倡议将对话和外交渠道置于优先地位,有利于为实现地区乃至更大范围和平、稳定、安全创造必要条件。日前,中国和巴基斯坦发表关于恢复海湾和中东地区和平稳定的五点倡议,呼吁停止敌对行动,尽快开启和谈,确保非军事目标安全、航道安全、联合国宪章首要地位。(新华社)
  • 特朗普:数量庞大的、完全空载的油轮正驶往美国

    2026-04-11 19:40
    4月11日,美国总统特朗普:数量庞大的、完全空载的油轮,其中一些是全球最大的油轮正驶往美国,(准备)在世界任何地方装载石油(和天然气)!我们的石油储量比排在我们之后的两个最大产油经济体的总和还要多,而且品质更高。
  • 特朗普:美国的石油更多、品质更好

    2026-04-11 19:38
    特朗普在其Truth平台发文表示"大量空载油轮,其中一些是世界上最大的油轮,此刻正驶往美国,装载着世界上最优质、最"甜美"的石油(和天然气!)。我们的石油储量超过了排名第二和第三的大产油国的总和——而且品质更高。我们恭候您的光临。抓紧时间!"
  • ArthurHayes再度买入2.6万枚HYPE持仓浮盈逾250万美元

    2026-04-11 19:31
    据Lookonchain监测,ArthurHayes在时隔近3个月后再次买入26,022枚HYPE(约110万美元)。目前其持有247,334枚HYPE(约1,044万美元),浮盈超250万美元。
  • 查看更多