脚本宝典收集整理的这篇文章主要介绍了Nginx代理时header头中带"_"信息丢失问题的解决,脚本宝典觉得挺不错的,现在分享给大家,也给大家做个参考。
前言
开发网关项目时,在请求时往请求头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)
总结
以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,如果有疑问大家可以留言交流,谢谢大家对脚本宝典的支持。
以上是脚本宝典为你收集整理的Nginx代理时header头中带"_"信息丢失问题的解决全部内容,希望文章能够帮你解决Nginx代理时header头中带"_"信息丢失问题的解决所遇到的问题。
本图文内容来源于网友网络收集整理提供,作为学习参考使用,版权属于原作者。
如您有任何意见或建议可联系处理。小编QQ:384754419,请注明来意。