nginx转发headers内容丢失解决办法 | 您所在的位置:网站首页 › nginx添加header › nginx转发headers内容丢失解决办法 |
问题:
开发网关项目时,在请求时往请求头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 的请求头参数。 |
CopyRight 2018-2019 实验室设备网 版权所有 |