最近用nginx做转发代理遇到一件很奇怪的事情,自定义的header信息丢失了,为什么会出现这样的问题那?
通过查阅资料发现,nginx确实存在这样的问题。nginx里是有关于相关的配置决定这块的,那就是说我们可以通过配置解决这块了?是的,没错。
原始的nginx配置不会转发host和IP等信息,对自定义的header信息不转发,具体如下:
proxy_set_header Host
host;proxysetheaderX−Real−IP
remote_addr;
proxy_set_header X-Forwarded-Server $host;
现在很多有又有疑问了?如果我不设置,能不能解决这样的问题那?
于是,我们都知道nginx是开源的,我们就可以通过查看源码来看看自定义header为什么会丢失?
在源码中,我们发现这段:
rc = ngx_http_parse_header_line(r, r->header_in, cscf->underscores_in_headers);
if (r->invalid_header && cscf->ignore_invalid_headers)
在ngx_http_parse_header_line() 函数中
if (ch == ‘_’) {
if (allow_underscores) {
hash = ngx_hash(hash, ch);
r->lowcase_header[i++] = ch;
i &= (NGX_HTTP_LC_HEADER_LEN – 1);
} else {
r->invalid_header = 1;
}
加粗部分说明了nginx会对自定义header做限制,默认 underscores_in_headers 为off,表示如果header name中包含下划线,则忽略掉。
恰好我自定义的header都是用的下划线。
处理办法:
1:配置中http部分 增加underscores_in_headers on; 配置
2:用减号-替代下划线符号_,避免这种变态问题。nginx默认忽略掉下划线可能有些原因