定制 furqansiddiqui/blockchain-core-php 二次开发

按需修改功能、优化性能、对接业务系统,提供一站式技术支持

邮箱:yvsm@zunyunkeji.com | QQ:316430983 | 微信:yvsm316

furqansiddiqui/blockchain-core-php

最新稳定版本:0.1.2

Composer 安装命令:

composer require furqansiddiqui/blockchain-core-php

包简介

Shared cryptographic primitives and chain identity abstractions for blockchain libraries.

README 文档

README

Tests Passing MIT License

A lightweight PHP library providing cryptographic primitives and elliptic curve abstractions specifically tailored for blockchain development.

Features

  • Elliptic Curves Support:
    • secp256k1 (Bitcoin, Ethereum)
    • secp256r1 (NIST P-256)
    • brainpoolP256r1
  • ECDSA (Elliptic Curve Digital Signature Algorithm):
    • High-performance pure-PHP implementation using ext-gmp.
    • Deterministic nonce generation via RFC 6979.
    • Canonical signature enforcement (BIP 66).
    • Public key recovery from signatures.
    • Support for compressed and uncompressed public keys.
  • EdDSA Support:
    • Abstractions for Edwards-curve Digital Signature Algorithm (e.g., Ed25519).
  • Security Focused:
    • Uses PHP 8.3 #[\SensitiveParameter] attribute to protect private keys in backtraces.
    • Implements Low-S normalization for ECDSA signatures.

⚠️ Disclaimer

This library exposes low-level cryptographic functionality. Use at your own risk. No warranties are provided. Perform an independent security review before production use.

Requirements

  • PHP 8.3 or higher.
  • ext-gmp extension.

Installation

You can install the package via composer:

composer require furqansiddiqui/blockchain-core-php

Usage

Secp256k1 Key Generation and Signing

use FurqanSiddiqui\Blockchain\Core\Crypto\Curves\Secp256k1;
use Charcoal\Buffers\Types\Bytes32;

$secp256k1 = new Secp256k1();

// 1. Generate a public key from a private key
$privateKey = new Bytes32(hex2bin("...32_byte_hex_private_key..."));
$publicKey = $secp256k1->generatePublicKey($privateKey);

echo "Public Key (X): " . bin2hex($publicKey->x->bytes()) . PHP_EOL;
echo "Public Key (Y): " . bin2hex($publicKey->y->bytes()) . PHP_EOL;

// 2. Sign a message hash (must be 32 bytes for secp256k1)
$msgHash = new Bytes32(hash("sha256", "Hello Blockchain", true));
$signature = $secp256k1->sign($privateKey, $msgHash);

echo "Signature R: " . bin2hex($signature->r->bytes()) . PHP_EOL;
echo "Signature S: " . bin2hex($signature->s->bytes()) . PHP_EOL;

// 3. Verify the signature
$isValid = $secp256k1->verify($publicKey, $signature, $msgHash);
var_dump($isValid); // bool(true)

Working with DER Signatures (BIP 66)

use FurqanSiddiqui\Blockchain\Core\Codecs\EcdsaDerCodec;

// Encode signature to DER
$der = $signature->toDER();
echo "DER: " . bin2hex($der) . PHP_EOL;

// Decode DER signature
// (Requires specifying expected scalar bit length)
use FurqanSiddiqui\Blockchain\Core\Enums\ScalarBitLength;
[$r, $s] = EcdsaDerCodec::decode(ScalarBitLength::Bits256, $der);

Testing

The library is thoroughly tested with vectors from libsecp256k1, RFC 6979, and standard NIST vectors.

To run the tests:

php phpunit.phar

License

This project is licensed under the MIT License - see the LICENSE file for details.

统计信息

  • 总下载量: 107
  • 月度下载量: 0
  • 日度下载量: 0
  • 收藏数: 1
  • 点击次数: 5
  • 依赖项目数: 1
  • 推荐数: 0

GitHub 信息

  • Stars: 1
  • Watchers: 0
  • Forks: 0
  • 开发语言: PHP

其他信息

  • 授权协议: MIT
  • 更新时间: 2026-02-10

承接程序开发

PHP开发

VUE

Vue开发

前端开发

小程序开发

公众号开发

系统定制

数据库设计

云部署

网站建设

安全加固