问题:
开发网关项目时,在请求时往请求头header中放入了签名sign_key信息,在接收请求时再从header中拿出,在本地调试时是可以的,但上线之后通过Nginx代理之后发现拿不到。
原因:
nginx代理默认会把header中参数的 "" 下划线去掉,所以后台服务器后就获取不到带""线的参数名。需要在http配置里添加这个参数配置为on。
underscores_in_headers on; #该属性默认为off,表示如果header name中包含下划线,则忽略掉。
扩展:
另外,如果只需要保留请求头中的某些特定下划线参数,可以在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" 的参数的值。
完整代码配置:
http {
# 全局配置
underscores_in_headers on;
server {
listen 80;
server_name example.com;
location / {
proxy_pass http://backend;
# 保留名为 X-MyHeader 的请求头参数
proxy_set_header X-MyHeader $http_x_my_header;
}
}
}
以上示例中,underscores_in_headers 指令被配置在 http 块中,保证了全局的下划线参数保留。而 proxy_set_header 指令则被配置在 location 块中,保留了名为 X-MyHeader 的请求头参数。
版权归原作者 十步杀一人_千里不留行 所有, 如有侵权,请联系我们删除。