samsonkwiz / idobfuscator
Reversible numeric ID obfuscation for PHP using BCMath
Requires
- php: >=7.0
- ext-bcmath: *
This package is not auto-updated.
Last update: 2025-06-16 10:28:34 UTC
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
- Go to https://github.com/samsonkwiz/idobfuscator
- Click "Code" → "Download ZIP", extract the archive
- Ensure Composer autoloader is available or include source files manually
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
-
Include Composer’s autoloader
require __DIR__ . '/vendor/autoload.php';
-
Import the class
use SamsonKwiz\IDObfuscator\IDObfuscator;
-
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}";
-
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.