NGINX代理导致请求头header中的信息丢失问题

问题描述:在请求时往请求头header中放入了签名sign_val信息,在接收请求时再从header中拿出,在本地调试时是可以的,但通过NGINX代理之后发现拿不到。
解决:
1.NGINX代理时加上请求头信息:

   location / 
	{
        proxy_next_upstream http_502 http_504 error timeout invalid_header;
        proxy_set_header Host  $host;
	    proxy_set_header X-Real-IP $remote_addr;
	    proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
	    proxy_pass http://web1;
        }

发现没有解决,最后发现是NGINX对header有所限制,下划线(_)不支持。
方法一:不用下划线
把下划线_改成其他的,如sign_val改成sign-val

方法二:从根本解除nginx的限制
nginx默认request的header的那么中包含’_’时,会自动忽略掉。
解决方法是:在nginx里的nginx.conf配置文件中的http部分中添加如下配置:
underscores_in_headers on; (默认 underscores_in_headers 为off)
我使用的是方法一,方法二没有试。
此文章同步到了我个人公众号:java面试工程师。关注公众号更加便于查阅。

  • 7
    点赞
  • 18
    收藏
    觉得还不错? 一键收藏
  • 3
    评论
Nginx是一款高性能的Web服务器和反向代理服务器,它可以通过代理来转发访问请求。如果在使用Nginx作为代理服务器时出现请求体丢失问题,可能是由于以下原因所导致: 1. 配置错误:Nginx的配置文件可能存在错误的代理设置,导致请求体丢失。可以检查Nginx的配置文件,特别是proxy_pass和proxy_set_header等相关指令的参数设置,确保正确配置。 2. 缓冲区设置不当:Nginx默认使用缓冲区来处理请求和响应,在某些情况下,可能会造成请求体丢失。可以通过调整Nginx配置的proxy_buffering和proxy_buffer_size等相关指令来解决。 3. 后端服务器问题:请求体丢失可能是后端服务器处理有问题导致的。可以检查后端服务器的日志,查看是否有错误或异常信息。如果后端服务器出现错误,可能无法正确解析请求体。 4. 请求体过大:如果请求体过大,可能会超出Nginx或后端服务器的配置限制,导致请求体丢失。可以尝试调整Nginx和后端服务器的相关配置参数,以支持更大的请求体。 5. 网络传输问题:请求体丢失可能与网络传输相关。可以检查网络连接和传输是否正常,尝试使用其他工具或方式进行请求测试,确保网络稳定。 综上所述,Nginx代理请求体丢失可能由多种原因导致,需要逐一排查相关配置、后端服务器、请求体大小、网络传输等方面的问题,以找到并解决具体原因。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值