Nginx代理时header头中带_的信息丢失的问题

开发网关项目时,在请求时往请求头header中放入了签名sign_key信息,在接收请求时再从header中拿出,在本地调试时是可以的,但上线之后通过Nginx代理之后发现拿不到。

1
2
3
4
5
6
7
8
9
10
11
12
location / {
proxy_set_header X-Real-IP $remote_addr;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
proxy_set_header Host $http_host;
proxy_set_header X-Nginx-Proxy true;

add_header Proxy-Node $upstream_addr;
add_header Proxy-Status $upstream_status;

proxy_http_version 1.1;
proxy_pass http://tianusa;
}

后来找到原因是因为Nginx对header有所限制,下划线(_)不支持

1.不用下划线
把下划线_改成其他的,如sign_key改成sign-key

2.从根本解除Nginx的限制
Nginx默认request的header的那么中包含’_’时,会自动忽略掉。
解决方法是:在nginx里的nginx.conf配置文件中的http部分中添加如下配置:

1
underscores_in_headers on; (默认 underscores_in_headers 为off)
  • 作者: Sam
  • 发布时间: 2019-02-01 23:28:37
  • 最后更新: 2019-12-09 23:03:26
  • 文章链接: https://ydstudios.gitee.io/post/a6b6fb0a.html
  • 版权声明: 本网所有文章除特别声明外, 禁止未经授权转载,违者依法追究相关法律责任!