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 的请求头参数。

猜你喜欢

转载自blog.csdn.net/m0_37609579/article/details/129118700