承接 tourze/tls-crypto-random 相关项目开发

从需求分析到上线部署,全程专人跟进,保证项目质量与交付效率

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

tourze/tls-crypto-random

最新稳定版本:0.0.1

Composer 安装命令:

composer require tourze/tls-crypto-random

包简介

Cryptographically secure random number generator for TLS protocol implementation

README 文档

README

PHP Version License Build Status Code Coverage

English | 中文

A cryptographically secure random number generator library for TLS protocol implementation, providing secure random bytes and integers generation using PHP's built-in cryptographic functions.

Features

  • Cryptographically Secure: Uses PHP's random_bytes() and random_int() functions
  • Simple Interface: Clean API with comprehensive error handling
  • Exception Safety: Proper exception handling for all edge cases
  • Type Safety: Full PHP 8.1+ type declarations
  • Performance: Efficient random number generation with minimal overhead

Installation

composer require tourze/tls-crypto-random

Requirements

  • PHP 8.1 or higher
  • OpenSSL extension (for secure random number generation)

Usage

Basic Usage

use Tourze\TLSCryptoRandom\CryptoRandom;

$random = new CryptoRandom();

// Generate random bytes
$randomBytes = $random->getRandomBytes(32); // 32 bytes
echo bin2hex($randomBytes); // Output: e.g., "a1b2c3d4e5f6..."

// Generate random integer
$randomInt = $random->getRandomInt(1, 100); // Integer between 1 and 100
echo $randomInt; // Output: e.g., 42

Interface Implementation

use Tourze\TLSCryptoRandom\Contract\RandomInterface;
use Tourze\TLSCryptoRandom\CryptoRandom;

function useRandomGenerator(RandomInterface $random): void
{
    // Generate a session ID
    $sessionId = bin2hex($random->getRandomBytes(16));
    
    // Generate a random port number
    $port = $random->getRandomInt(1024, 65535);
    
    echo "Session ID: {$sessionId}\n";
    echo "Port: {$port}\n";
}

$random = new CryptoRandom();
useRandomGenerator($random);

Error Handling

use Tourze\TLSCryptoRandom\CryptoRandom;
use Tourze\TLSCryptoRandom\Exception\RandomException;

$random = new CryptoRandom();

try {
    // Invalid length
    $random->getRandomBytes(0);
} catch (RandomException $e) {
    echo "Error: " . $e->getMessage(); // "随机字节长度必须大于0"
}

try {
    // Invalid range
    $random->getRandomInt(100, 1);
} catch (RandomException $e) {
    echo "Error: " . $e->getMessage(); // "最小值不能大于最大值"
}

API Reference

CryptoRandom Class

Implements RandomInterface and provides cryptographically secure random number generation.

Methods

getRandomBytes(int $length): string

Generates cryptographically secure random bytes.

  • Parameters:
    • $length (int): Number of bytes to generate (must be > 0)
  • Returns: string - Random bytes
  • Throws: RandomException - If length is invalid or generation fails
getRandomInt(int $min, int $max): int

Generates cryptographically secure random integer within specified range.

  • Parameters:
    • $min (int): Minimum value (inclusive)
    • $max (int): Maximum value (inclusive)
  • Returns: int - Random integer
  • Throws: RandomException - If range is invalid or generation fails

RandomInterface

Interface for random number generators.

interface RandomInterface
{
    public function getRandomBytes(int $length): string;
    public function getRandomInt(int $min, int $max): int;
}

Exceptions

RandomException

Thrown when random number generation fails or invalid parameters are provided.

CryptoException

Base exception class for cryptographic operations.

Security Considerations

  • Uses PHP's cryptographically secure random_bytes() and random_int() functions
  • Suitable for generating session tokens, salts, and other security-sensitive values
  • No fallback to insecure random number generators
  • Proper error handling prevents silent failures

Performance

  • Efficient direct usage of PHP's built-in functions
  • No additional entropy collection overhead
  • Suitable for high-performance applications
  • Tested with large data generation (100KB+ in under 1 second)

Testing

The package includes comprehensive tests covering:

  • Basic functionality
  • Edge cases and error conditions
  • Performance characteristics
  • Cryptographic quality (basic entropy testing)
  • Concurrent usage scenarios

Run tests with:

./vendor/bin/phpunit packages/tls-crypto-random/tests

License

MIT License - see LICENSE file for details.

统计信息

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

GitHub 信息

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

其他信息

  • 授权协议: MIT
  • 更新时间: 2025-05-23

承接程序开发

PHP开发

VUE

Vue开发

前端开发

小程序开发

公众号开发

系统定制

数据库设计

云部署

网站建设

安全加固