模块 ngx_http_image_filter_module

Example Configuration
Directives
     image_filter
     image_filter_buffer
     image_filter_interlace
     image_filter_jpeg_quality
     image_filter_sharpen
     image_filter_transparency
     image_filter_webp_quality

ngx_http_image_filter_module模块 (0.7.54+) 是一个过滤器,可转换 JPEG、GIF、PNG 和 WebP 格式的图像。

该模块不是默认构建的,需要通过 --with-http_image_filter_module 配置参数启用。

该模块使用 libgd库。建议使用该库的最新可用版本。

WebP 格式支持出现在 1.11.6 版本中。要转换这种格式的图像,libgd必须使用 WebP 支持来编译该库。

配置示例

location /img/ {
    proxy_pass   http://backend;
    image_filter resize 150 100;
    image_filter rotate 90;
    error_page   415 = /empty;
}

location = /empty {
    empty_gif;
}

指令

句法: image_filter off;
image_filter test;
image_filter size;
image_filter rotate 90 | 180 | 270;
image_filter resize width height;
image_filter crop width height;
默认:
image_filter off;
语境: location

设置对图像执行的转换类型:

off
关闭周围位置的模块处理。
test
确保响应是 JPEG、GIF、PNG 或 WebP 格式的图像。否则,返回415(不支持的媒体类型)错误。
size
以 JSON 格式输出有关图像的信息,例如:
{ "img" : { "width": 100, "height": 100, "type": "gif" } }
如果出现错误,输出如下:
{}
rotate 90| 180|270
将图像逆时针旋转指定的度数。参数值可以包含变量。该模式可以单独使用,也可以与 resizecrop转换一起使用。
resize width height
按比例将图像缩小到指定尺寸。如果只减少一个维度,可以将另一个维度指定为“ -”。如果发生错误,服务器将返回代码 415(不支持的媒体类型)。参数值可以包含变量。当与rotate参数一起使用时,旋转发生在缩减 之后。
crop width height
按比例将图像缩小到较大的边尺寸,并裁剪另一边的无关边缘。如果只减少一个维度,可以将另一个维度指定为“ -”。如果发生错误,服务器将返回代码 415(不支持的媒体类型)。参数值可以包含变量。当与rotate参数一起使用时,旋转发生在缩减 之前。

句法: image_filter_buffer size;
默认:
image_filter_buffer 1M;
语境: http, server,location

设置用于读取图像的缓冲区的最大大小。当超出大小时,服务器返回错误 415(不支持的媒体类型)。

句法: image_filter_interlace on | off;
默认:
image_filter_interlace off;
语境: http, server,location

该指令出现在 1.3.15 版本中。

如果启用,最终图像将是隔行扫描的。对于 JPEG,最终图像将采用“渐进式 JPEG”格式。

句法: image_filter_jpeg_quality quality;
默认:
image_filter_jpeg_quality 75;
语境: http, server,location

设置所需的quality转换后的 JPEG 图像。可接受的值范围为 1 到 100。较小的值通常意味着较低的图像质量和较少的数据传输。最大建议值为 95。参数值可以包含变量。

句法: image_filter_sharpen percent;
默认:
image_filter_sharpen 0;
语境: http, server,location

提高最终图像的清晰度。锐化百分比可以超过 100。零值会禁用锐化。参数值可以包含变量。

句法: image_filter_transparency on|off;
默认:
image_filter_transparency on;
语境: http, server,location

定义在使用调色板指定的颜色转换 GIF 图像或 PNG 图像时是否应保留透明度。透明度的损失导致图像质量更好。PNG 中的 Alpha 通道透明度始终保留。

句法: image_filter_webp_quality quality;
默认:
image_filter_webp_quality 80;
语境: http, server,location

该指令出现在版本 1.11.6 中。

设置所需的quality转换后的 WebP 图像。可接受的值范围为 1 到 100。较小的值通常意味着较低的图像质量和较少的数据传输。参数值可以包含变量。