问题
开发网关项目时,在请求时往请求头header中放入了签名sign_key信息,在接收请求时再从header中拿出,在本地调试时是可以的,但上线之后通过Nginx代理之后发现拿不到。
原因
nginx代理默认会把header中参数的 "" 下划线去掉,所以后台服务器后就获取不到带""线的参数名。需要在http配置里添加这个参数配置为on。
解决
方法一:不用下划线
把下划线_改成其他的,如sign_val改成sign-val
方法二:从根本解除nginx的限制
在nginx里的nginx.conf配置文件中的http部分中添加如下配置:underscores_in_headers on; (默认 underscores_in_headers 为off)
underscores_in_headers on; (默认 underscores_in_headers 为off)
方法三:
另外,如果只需要保留请求头中的某些特定下划线参数,可以在Nginx配置文件中添加以下语句:
ignore_invalid_headers off;
然后在server或location段中,使用proxy_set_header指令来设置需要保留的请求头参数。例如:
location / {
proxy_pass http://backend;
proxy_set_header X-MyHeader $http_x_my_header;
}
以上示例中,Nginx会保留名为 "X-MyHeader" 的请求头参数,并将它的值设置为原请求头中名为 "x-my-header" 的参数的值。
完整代码配置:
server {
listen 80;
server_name example.com;
location / {
proxy_pass http://backend;
# 保留名为 X-MyHeader 的请求头参数
proxy_set_header X-MyHeader $http_x_my_header;
}
}