laravel-at / laravel-image-sanitize
A small but handy package to prevent malicious code execution coming into your application through uploaded image files.
Package info
github.com/laravel-at/laravel-image-sanitize
pkg:composer/laravel-at/laravel-image-sanitize
Requires
- php: ^8.3
- ext-fileinfo: *
- illuminate/container: ^12.0|^13.0
- illuminate/contracts: ^12.0|^13.0
- illuminate/http: ^12.0|^13.0
- illuminate/support: ^12.0|^13.0
- intervention/image: ^4.0
Requires (Dev)
- laravel/framework: ^12.0|^13.0
- laravel/pint: ^1.29
- orchestra/testbench: ^10.0|^11.0
- phpstan/phpstan: ^2.2
README
It prevents malicious code execution!
This is a small but handy package to prevent malicious code execution coming into your application through uploaded images. It was created after being inspired by @appelsiini's talk on How to Hack your Laravel Application
Installation
This version requires PHP 8.3+, Laravel 12 or 13, and Intervention Image 4.
You can install the package via composer:
composer require laravel-at/laravel-image-sanitize
Usage
Apply the middleware to routes that receive image uploads:
use App\Http\Controllers\FileController; use LaravelAt\ImageSanitize\ImageSanitizeMiddleware; Route::post('/files', [FileController::class, 'upload']) ->name('file.upload') ->middleware(ImageSanitizeMiddleware::class);
If you prefer a middleware alias, register it in your application's bootstrap/app.php file:
use Illuminate\Foundation\Configuration\Middleware; use LaravelAt\ImageSanitize\ImageSanitizeMiddleware; ->withMiddleware(function (Middleware $middleware): void { $middleware->alias([ 'image-sanitize' => ImageSanitizeMiddleware::class, ]); })
Then use the alias on your upload routes:
Route::post('/files', [FileController::class, 'upload']) ->name('file.upload') ->middleware('image-sanitize');
If you want to learn more about middlewares, please check out the official Laravel documentation.
Configuration
You may publish the configuration file:
php artisan vendor:publish --tag=image-sanitize-config
The default configuration scans JPEG, PNG, GIF, BMP, and WebP uploads for suspicious byte patterns, then re-encodes matching images through Intervention Image. SVG files are not supported by default.
return [ 'allowed_mime_types' => [ 'image/jpeg', 'image/png', 'image/gif', 'image/bmp', 'image/webp', ], 'patterns' => [ '<?php', 'phar', ], 'driver' => \Intervention\Image\Drivers\Gd\Driver::class, 'quality' => 100, 'auto_orientation' => true, 'decode_animation' => true, 'strip_metadata' => true, ];
You can also use the facade directly:
if (ImageSanitize::detect($contents)) { $contents = (string) ImageSanitize::sanitize($contents); }
Testing
composer test
Run the full local quality check:
composer check
Or run the individual checks:
composer format-test
composer analyse
composer test
Changelog
Please see CHANGELOG for more information on what has changed recently.
Contributing
Please see CONTRIBUTING for details.
Security
If you discover any security related issues, please email adrian@nuernberger.me instead of using the issue tracker.
Credits
- Adrian Nürnberger
- Mathias Onea
- Logo by Caneco
License
The MIT License (MIT). Please see License File for more information.
