模块 ngx_http_charset_module
示例配置 指令 charset charset_map charset_types override_charset source_charset |
ngx_http_charset_module
模块将指定的字符集添加到“Content-Type”响应头字段。此外,该模块可以将数据从一种字符集转换到另一种字符集,但有一些限制
- 转换是单向的——从服务器到客户端,
- 只能转换单字节字符集
- 或单字节字符集到/从 UTF-8。
示例配置
include conf/koi-win; charset windows-1251; source_charset koi8-r;
指令
语法 |
charset |
---|---|
默认值 |
charset off; |
上下文 |
http 、server 、location 、if in location |
将指定的字符集添加到“Content-Type”响应头字段。如果此字符集不同于在 source_charset 指令中指定的字符集,则执行转换。
参数 off
取消将字符集添加到“Content-Type”响应头字段。
可以使用变量定义字符集
charset $charset;
在这种情况下,变量的所有可能值都必须至少以 charset_map、charset 或 source_charset 指令的形式出现在配置中一次。对于 utf-8
、windows-1251
和 koi8-r
字符集,将文件 conf/koi-win
、conf/koi-utf
和 conf/win-utf
包含到配置中就足够了。对于其他字符集,只需创建一个虚构的转换表即可,例如
charset_map iso-8859-5 _ { }
此外,可以在“X-Accel-Charset”响应头字段中设置字符集。可以使用 proxy_ignore_headers、fastcgi_ignore_headers、uwsgi_ignore_headers、scgi_ignore_headers 和 grpc_ignore_headers 指令禁用此功能。
语法 |
charset_map |
---|---|
默认值 | — |
上下文 |
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-r
到windows-1251
以及从koi8-r
和windows-1251
到utf-8
的完整转换表在分发文件conf/koi-win
、conf/koi-utf
和conf/win-utf
中提供。
语法 |
charset_types |
---|---|
默认值 |
charset_types text/html text/xml text/plain text/vnd.wap.wml application/javascript application/rss+xml; |
上下文 |
http 、server 、location |
此指令出现在 0.7.9 版中。
除了“text/html
”之外,还启用对具有指定 MIME 类型的响应中的模块处理。特殊值“*
”匹配任何 MIME 类型 (0.8.29)。
在 1.5.4 版之前,“application/x-javascript
”用作默认 MIME 类型,而不是“application/javascript
”。
语法 |
override_charset |
---|---|
默认值 |
override_charset off; |
上下文 |
http 、server 、location 、if in location |
当响应在“Content-Type”响应头字段中已带有字符集时,确定是否应针对从代理或 FastCGI/uwsgi/SCGI/gRPC 服务器收到的答案执行转换。如果启用转换,则收到的响应中指定的字符集用作源字符集。
应当注意,如果在子请求中收到响应,则始终执行从响应字符集到主请求字符集的转换,而不管override_charset
指令设置如何。
语法 |
source_charset |
---|---|
默认值 | — |
上下文 |
http 、server 、location 、if in location |
定义响应的源字符集。如果此字符集不同于在charset指令中指定的字符集,则执行转换。