模块 ngx_http_charset_module

示例配置
指令
     charset
     charset_map
     charset_types
     override_charset
     source_charset

ngx_http_charset_module 模块将指定的字符集添加到“Content-Type”响应头字段。此外,该模块可以将数据从一个字符集转换为另一个字符集,但有一些限制。

示例配置

include        conf/koi-win;

charset        windows-1251;
source_charset koi8-r;

指令

语法 charset charset | off;
默认值
charset off;
上下文 httpserverlocationif in location

将指定的字符集添加到“Content-Type”响应头字段。如果此字符集与 source_charset 指令中指定的字符集不同,则执行转换。

参数 off 取消将字符集添加到“Content-Type”响应头字段。

可以使用变量定义字符集。

charset $charset;

在这种情况下,变量的所有可能值都需要在配置中至少以 charset_mapcharsetsource_charset 指令的形式出现一次。对于 utf-8windows-1251koi8-r 字符集,只需将 conf/koi-winconf/koi-utfconf/win-utf 文件包含到配置中即可。对于其他字符集,只需创建一个虚构的转换表即可,例如

charset_map iso-8859-5 _ { }

此外,可以在“X-Accel-Charset”响应头字段中设置字符集。可以使用 proxy_ignore_headersfastcgi_ignore_headersuwsgi_ignore_headersscgi_ignore_headersgrpc_ignore_headers 指令禁用此功能。

语法 charset_map charset1 charset2 { ... }
默认值
上下文 http

描述从一个字符集到另一个字符集的转换表。使用相同的数据构建反向转换表。字符代码以十六进制给出。范围 80-FF 中缺少的字符将替换为“?”。从 UTF-8 转换时,一字节字符集中缺少的字符将替换为“&#XXXX;”。

示例

charset_map koi8-r windows-1251 {
    C0 FE ; # small yu
    C1 E0 ; # small a
    C2 E1 ; # small b
    C3 F6 ; # small ts
    ...
}

在描述到 UTF-8 的转换表时,UTF-8 字符集的代码应放在第二列,例如

charset_map koi8-r utf-8 {
    C0 D18E ; # small yu
    C1 D0B0 ; # small a
    C2 D0B1 ; # small b
    C3 D186 ; # small ts
    ...
}

koi8-rwindows-1251 以及从 koi8-rwindows-1251utf-8 的完整转换表在发行版文件 conf/koi-winconf/koi-utfconf/win-utf 中提供。

语法 charset_types mime-type ...;
默认值
charset_types text/html text/xml text/plain text/vnd.wap.wml
application/javascript application/rss+xml;
上下文 httpserverlocation

此指令出现在版本 0.7.9 中。

除了“text/html”之外,还启用模块在具有指定 MIME 类型的响应中进行处理。特殊值“*”匹配任何 MIME 类型(0.8.29)。

在 1.5.4 版本之前,使用“application/x-javascript”作为默认 MIME 类型,而不是“application/javascript”。

语法 override_charset on | off;
默认值
override_charset off;
上下文 httpserverlocationif in location

确定是否应为从代理服务器或 FastCGI/uwsgi/SCGI/gRPC 服务器接收到的响应执行转换,当响应已经在“Content-Type”响应头字段中携带字符集时。如果启用转换,则接收到的响应中指定的字符集将用作源字符集。

需要注意的是,如果在子请求中接收到响应,则始终执行从响应字符集到主请求字符集的转换,而不管 override_charset 指令设置如何。

语法 source_charset charset;
默认值
上下文 httpserverlocationif in location

定义响应的源字符集。如果此字符集与 charset 指令中指定的字符集不同,则执行转换。