samsonkwiz/idobfuscator 问题修复 & 功能扩展

解决BUG、新增功能、兼容多环境部署,快速响应你的开发需求

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

samsonkwiz/idobfuscator

最新稳定版本:v1.0.0

Composer 安装命令:

composer require samsonkwiz/idobfuscator

包简介

Reversible numeric ID obfuscation for PHP using BCMath

README 文档

README

Secure, reversible numeric ID obfuscation for PHP using BCMath.

IDObfuscator lets you:

  • Generate unpredictable numbers for tokens, card numbers, and references.
  • Mask your database auto-increment IDs with deterministic, non-sequential values.
  • Protect sensitive numeric identifiers in URLs, APIs, and logs.

Thanks to BCMath, it handles arbitrarily large integers and guarantees exact round-trip encoding/decoding.

Requirements

  • PHP 7.0 or higher
  • BCMath extension (ext-bcmath)

Installation

Install via Composer (recommended):

composer require samsonkwiz/idobfuscator

Other installation methods

1. Clone the repository and install dependencies

git clone https://github.com/samsonkwiz/idobfuscator.git
cd idobfuscator
composer install

2. Download ZIP

3. Git submodule

git submodule add https://github.com/samsonkwiz/idobfuscator.git path/to/IDObfuscator

Then update your project's composer.json autoload section:

"autoload": {
  "psr-4": {
    "SamsonKwiz\\IDObfuscator\\": "src/"
  }
}

Run:

composer dump-autoload

4. Packagist

The package is now available on Packagist. Simply run:

composer require samsonkwiz/idobfuscator

Usage## Usage

  1. Include Composer’s autoloader

    require __DIR__ . '/vendor/autoload.php';
  2. Import the class

    use SamsonKwiz\IDObfuscator\IDObfuscator;
  3. Instantiate and encode/decode IDs

    A. Using instance methods

    // Create a new obfuscator instance with default settings
    $obfuscator = new IDObfuscator();
    
    $originalId = 12345;
    $encoded    = $obfuscator->encode($originalId);   // e.g. "004829374"
    $decoded    = $obfuscator->decode($encoded);     // back to 12345
    
    echo "ID {$originalId}{$encoded}{$decoded}";

    B. Using static helper methods

    $originalId = 54321;
    $encoded    = IDObfuscator::obfuscate($originalId);
    $decoded    = IDObfuscator::deobfuscate($encoded);
    
    echo "ID {$originalId}{$encoded}{$decoded}";
  4. Customize salt, key, and output length (optional)

    $salt     = '246802468';
    $key      = '13579135';
    $length   = 12;  // exact length of the obfuscated string
    
    // Create a custom obfuscator
    $customOb = new IDObfuscator($salt, $key, $length);
    
    $id       = 98765;
    $encoded  = $customOb->encode($id);
    $decoded  = $customOb->decode($encoded);
    
    echo "Custom ID {$id}{$encoded}{$decoded}";

Contributing

Contributions are welcome! Please fork the repository and open a pull request.

License

This library is released under the MIT License.

统计信息

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

GitHub 信息

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

其他信息

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