模块 ngx_http_sub_module

示例配置
指令
     sub_filter
     sub_filter_last_modified
     sub_filter_once
     sub_filter_types

ngx_http_sub_module 模块是一个过滤器,它通过用另一个字符串替换一个指定字符串来修改响应。

此模块未默认构建,应使用 --with-http_sub_module 配置参数启用它。

示例配置

location / {
    sub_filter '<a href="http://127.0.0.1:8080/'  '<a href="https://$host/';
    sub_filter '<img src="http://127.0.0.1:8080/' '<img src="https://$host/';
    sub_filter_once on;
}

指令

语法 sub_filter string replacement;
默认值
上下文 httpserverlocation

设置要替换的字符串和替换字符串。要替换的字符串匹配时不区分大小写。要替换的字符串 (1.9.4) 和替换字符串可以包含变量。可以在同一配置级别指定多个 sub_filter 指令 (1.9.4)。仅当当前级别未定义 sub_filter 指令时,才会从上一个配置级别继承这些指令。

语法 sub_filter_last_modified on | off;
默认值
sub_filter_last_modified off;
上下文 httpserverlocation

此指令出现在 1.5.1 版中。

允许在替换期间保留原始响应中的“上次修改”标头字段,以方便响应缓存。

默认情况下,由于在处理期间响应的内容已修改,因此该标头字段会被删除。

语法 sub_filter_once on | off;
默认值
sub_filter_once on;
上下文 httpserverlocation

指示是否仅查找每个要替换的字符串一次或重复查找。

语法 sub_filter_types mime-type ...;
默认值
sub_filter_types text/html;
上下文 httpserverlocation

除了“text/html”之外,还启用对具有指定 MIME 类型的响应中的字符串替换。特殊值“*”匹配任何 MIME 类型 (0.8.29)。