mwarcz/segami
最新稳定版本:v2.1.0
Composer 安装命令:
composer require mwarcz/segami
包简介
PHP library that allows you to edit image dimensions, convert image format, cache generated images, record last access to generated image in cache, remove images from cache that have not been used for long time, all based on image name.
README 文档
README
Segami
Segami is simple PHP library that allows edit image dimensions, convert image format, cache generated images, record last access to generated image in cache, remove images from cache that have not been used for long time, all based on image suffix in name.
Key features
- Convert image format
- Basic function of library is to convert image into various raster formats (PNG, GIF, JPEG, WebP, etc.).
- Example:
sample.png@.jpg,sample.png@.webp
- Create image crop
- Optional function allows you to crop image in required dimensions.
- Example:
sample.png@c200x100.png,sample.png@c300.jpg
- Resize image
- Optional function that allows you to change size of image in the required dimensions and fill type (fill, contain, cover).
- Example:
sample.png@r200x100_cover.png,sample.png@r300.jpg
- Set image quality/compression
- Optional feature to set image quality/compression, which affects resulting file size and compression for selected format.
- Example:
sample.png@q80.jpg,sample.png@q50.webp
- Store generated images (cache)
- Library allows storing generated images in cache directory for quick retrieval of generated image, as name of image precisely defines its properties.
- Image filenames are normalized in background to avoid unnecessary duplication.
- ex. 1:
sample.png@c200.png=sample.png@c200x200.png - ex. 2:
sample.png@r100x100_cover.png=sample.png@r100_r.png
- ex. 1:
- Automatic removal of long-term unused images from cache
- Library provides functions for removing previously stored images to help clear disk space of images that have not been used for long time.
- Limiters limiting names of required images
- Optionally, it is possible to restrict image names that modify original image.
- It is recommended to limit image names when storing to cache is enabled, so that potential attacker has difficult time attacking you.
Requirements
- PHP 8.1+
- Mandatory optional:
- ext-gd
- ext-imagick s instalovaným ImageMagick
- Mandatory optional:
Installation
Segami library is available on Packagist and installing via Composer is recommended way to install it.
Just use the command in terminal:
composer require mwarcz/segami
Or manually add to composer.json file:
{
"require": {
"php": "^8.1",
"mwarcz/segami": "dev-master"
}
}
Note: Replace
dev-masterwith specific version constraint. See Packagist for available versions.
Usage
Short example of possible basic use of library:
$segami = new Segami([ // Selected path to dir with original images 'path_to_original_images' => __DIR__ . '/original', // Selected path to dir with generated images 'path_to_generated_images' => __DIR__ . '/generated', // Selected plugins for generating images 'plugin' => [ // CorePlugin is required minimum - enable core name parsing and image format conversion 'core' => new CorePlugin(), // Optional ResizePlugin - enable/add possibility resize image 'resize' => new ResizePlugin(), // Optional QualityPlugin - enable/add possibility quality image 'quality' => new QualityPlugin(), ], // Selected limiter with rules for generated images 'limiter' => new FreeImageLimiter(), // Selected image engine 'image_factory' => new ImageImagickFactory(), // Selected logger for logging access to images 'image_logger' => new ImageLoggerNone(), ]); try { $segami->smartReturnImage($_GET['image'], isset($_GET['cache'])); } catch (\Throwable $e) { http_response_code(404); }
Repository contains set of samples of various use case:
More detailed information about functions and use case of Segami library can be found in upcoming documentation.
License
Segami is licensed under MIT license.
TODO roadmap
See Czech version.
统计信息
- 总下载量: 23
- 月度下载量: 0
- 日度下载量: 0
- 收藏数: 0
- 点击次数: 0
- 依赖项目数: 0
- 推荐数: 0
其他信息
- 授权协议: MIT
- 更新时间: 2023-06-05