开发网关项目时,在请求时往请求头header中放入了签名sign_key信息,在接收请求时再从header中拿出,在本地调试时是可以的,但上线之后通过nginx代理之后发现拿不到。
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部分中添加如下配置:
underscores_in_headers on; (默认 underscores_in_headers 为off)