The Laravel Encoder package provides a robust and secure way to encode
and decode
IDs & Strings using customizable Base encoding mechanisms (Base62). With support for variable-length encoding, mappers for added security, and seamless integration with Laravel, this package is ideal for obfuscating sensitive data or creating URL-safe identifiers.
⚠️ Note: This package is meant for obfuscation, not encryption. Do not use it for storing or transmitting sensitive data securely.
- Features
- Requirements
- Installation
- Quick Example
- Documentation
- Why I Built This
- Why Base62?
- Why Choose This Package?
- Contributing
- Changelog
- License
- Base Encoding: Supports customizable bases (Base62).
- Variable-Length Encoding: Allows encoding with custom lengths for obfuscation.
- Mapper-Based Obfuscation: Adds an extra layer of security by using configurable prime numbers and mappers.
- Customizable Configuration: Publish the configuration file to override default mappers.
- Exception Handling: Provides detailed exceptions for invalid inputs.
- Laravel Integration: Works seamlessly with Laravel’s service container and configuration system.
- Security: Protects sensitive IDs by ensuring encoded values are not easily reversible without the correct configuration.
- PHP 8.1 or higher
- Laravel 10 or higher (optional, for Laravel integration)
- PHP extensions:
bcmath
,mbstring
Step 1: Install via Composer
composer require nassiry/laravel-encoder
use Nassiry\Encoder\Facades\Encoder;
$encoded = Encoder::encodeId(12345);
$decoded = Encoder::decodeId($encoded);
echo $encoded; // Encoded Strings
echo $decoded; // 12345
$encoded = Encoder::encodeString('Hello World');
$decoded = Encoder::decodeString($encoded);
echo $encoded; // Encoded Strings
echo $decoded; // Hello World
Encode/decode
strings
and IDs
using Laravel container, facades, or dependency injection.
Use in any PHP project, no Laravel required.
Customize encoding behavior, mappers, and defaults.
Add your own Base58, Base64, or custom encoders.
Covers validation, decoding issues, and base errors.
Run the test suite or contribute improvements.
Laravel's encryption
produced long strings
, and Base64 needed extra steps to be URL-safe. I wanted a clean, simple way to encode IDs and strings short, URL-safe, and easy to configure.
Full Story & Benefits
Feel free to submit issues or pull requests to improve the package. Contributions are welcome! Let’s improve it together!
See CHANGELOG for release details.
This package is open-source software licensed under the MIT license.