uak35/laravel-response-compression
最新稳定版本:v0.0.6
Composer 安装命令:
composer require uak35/laravel-response-compression
包简介
Laravel response compression middleware
README 文档
README
Boost your Laravel application's performance by optimizing HTTP responses with middleware for compression.
Installation
Install the package via Composer:
composer require uak35/laravel-response-compression
Publish the configuration file:
php artisan vendor:publish --provider="Uak35\ResponseCompression\ResponseCompressionServiceProvider"
Middleware Overview
This package provides the following middleware:
Compression Middleware
Applies Gzip, Brotli, or Zstd compression to HTTP responses based on client support. This reduces the size of the response payload and enhances load times.
Ideal For: Large JSON responses, static files, or data-intensive endpoints.
Note
To use Brotli effectively, ensure that the Brotli PHP extension is properly installed. https://pecl.php.net/package/brotli
Warning
When using Brotli, a client-side decoding error may occur with non-secure connections, as modern browsers generally support Brotli compression only over HTTPS.
Note
To use Zstandard (ZSTD) effectively, ensure that the ZSTD PHP extension is properly installed. https://pecl.php.net/package/zstd
Setup
Register Middleware
Global Middleware
Apply the middleware globally to all requests:
// bootstrap/app.php ->withMiddleware(function (Middleware $middleware) { ... $middleware->web(append: [ ... \Uak35\ResponseCompression\Middleware\CompressResponse::class, ]); })
Route Middleware
Alternatively, register it as route middleware for selective application:
use Uak35\ResponseCompression\Middleware\CompressResponse; Route::get('/profile', function () { // ... })->middleware(CompressResponse::class);
Config
/** * Enable or disable the response compression. */ 'enabled' => env('RESPONSE_COMPRESSION_ENABLED', true), /** * The compression algorithm to use. Can be either 'gzip' or 'br'. */ 'algorithm' => env('RESPONSE_COMPRESSION_ALGORITHM', 'gzip'), /** * The minimum length of the response content to be compressed. */ 'min_length' => env('RESPONSE_COMPRESSION_MIN_LENGTH', 1024), 'gzip' => [ /** * The level of compression. Can be given as 0 for no compression up to 9 * for maximum compression. If not given, the default compression level will * be the default compression level of the zlib library. * * @see https://www.php.net/manual/en/function.gzencode.php */ 'level' => env('RESPONSE_COMPRESSION_GZIP_LEVEL', 5), ], 'br' => [ /** * The level of compression. Can be given as 0 for no compression up to 11 * for maximum compression. If not given, the default compression level will * be the default compression level of the brotli library. * * @see https://www.php.net/manual/en/function.brotli-compress.php */ 'level' => env('RESPONSE_COMPRESSION_BROTLI_LEVEL', 5), 'non_supporting_user_agent_prefixes' => [ 'ELB-HealthChecker/', 'PostmanRuntime/', 'axios/', 'Dart/', ], ], 'zstd' => [ /** * The level of compression. Can be given as 0 for no compression up to 22 * for maximum compression. If not given, the default compression level will * be the default compression level of the zstd library. * * @see https://github.com/kjdev/php-ext-zstd */ 'level' => env('RESPONSE_COMPRESSION_ZSTD_LEVEL', 3), 'non_supporting_user_agent_prefixes' => [ 'ELB-HealthChecker/', 'PostmanRuntime/', 'axios/', 'Dart/', 'IntelliJ HTTP Client/', ], ], 'try_multiple_encodings' => env('RESPONSE_COMPRESSION_TRY_MULTIPLE_ENCODINGS', false), 'multiple_encodings_order' => env('RESPONSE_COMPRESSION_MULTIPLE_ENCODINGS_ORDER', 'br,zstd,gzip')
Testing
composer test
Contributing
Contributions are welcome! Submit a pull request or open an issue to discuss new features or improvements.
License
The MIT License (MIT). Please see License File for more information.
统计信息
- 总下载量: 165
- 月度下载量: 0
- 日度下载量: 0
- 收藏数: 0
- 点击次数: 0
- 依赖项目数: 0
- 推荐数: 0
其他信息
- 授权协议: MIT
- 更新时间: 2025-10-22