Nginx转发post请求变get请求

这篇具有很好参考价值的文章主要介绍了Nginx转发post请求变get请求。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

最近用nginx转发请求,但是明明是post请求,打到服务上确实get请求,body中的参数都没了,于是去查背后详细的原因。

背景

Nginx配置

  • ip及端口:192.20.81.34:8081
  • conf关键配置:
location /select/dosomething/ {
      proxy_pass http://xx.xx.xx.xx:18000/select/dosomething/;
 }

请求连接

http://192.20.81.34:8081/select/dosomething

网上查询处理方法

1.http请求被转发至https请求引起重定向,导致post变get,显然这个和我的情况无关

2.location后连接多了个/,把/去掉就好了,如:解决 nginx 转发POST变成GET - 灰信网(软件开发博客聚合)https://www.freesion.com/article/99851192529/

第二个好使!!

问题分析

虽然按照第二个把/去掉后正常了,但是那篇文章中并没有解释为什么会导致这样的现象,于是本着好奇的态度,去查了一下原因,结果如下

一、为什么post会转get?

post转get其实不是Nginx导致的!而是重定向导致的!出现这种情况,你可以在nginx的logs/access.log里面看到有两条记录。

"POST /select/dosomthing HTTP/1.1" 301 185 "-" "PostmanRuntime/7.28.4"
"GET /select/dosomthing/ HTTP/1.1" 500 389 "http://192.20.81.34:8081/select/dosomthing" "PostmanRuntime/7.28.4"

这两条记录可以看出,我是使用postman进行请求,第一条post请求nginx收到了并返回了301HTTP状态码,接着postman就发出了第二条请求,第二条请求就变成了GET请求,且请求最后加了/,变成了

http://192.20.81.34:8081/select/dosomething/

查询301的状态码对应的是永久重定向,正常情况下请求发送方接到301状态码,表示需要重定向,于是会改变请求的url再次请求,但是!有的时候会将请求强行改为get,详情可见:https://developer.mozilla.org/zh-CN/docs/Web/HTTP/Redirectionshttps://developer.mozilla.org/zh-CN/docs/Web/HTTP/Redirections

可以看到 

Nginx转发post请求变get请求

有些时候处理301状态码时,会把请求方法强行改成get,当然这个问题也被人发现,后面区分出了308状态码,这个状态码不会改变请求方式。

所以是301状态码引起了post请求变成了get请求,而整个流程就较为清晰了:

  1. nginx收到post请求
  2. 返回301状态码,并指定新的访问连接,且该连接就是原连接+/
  3. 发送方收到301状态码,将请求方式改为get,并请求新连接
  4. 服务收到get请求,body参数全部失效

二、为什么会发生重定向?

这个重定向似乎发生的非常隐蔽,似乎是触发了nginx的某种机制,从现象上看,该机制是nginx自动添加末尾斜杠的机制。

我在nginx中配置的连接是

/select/dosomething/

而我实际请求的连接是

/select/dosomething

明显(虽然排查的时候也没看出来)末尾少了一个/,这种情况下nginx会通过301重定向的方式来补全最后/,让发送方重新请求,从而完成匹配。

这个机制也有人提到过,比如:nginx url自动加斜杠问题 - 陈一风 - 博客园一、首先对比说明Nginx以下两个现象: 1. 访问的uri最后带斜杠 http://localhost/product/ >>>> 查找 product下的index页面,存https://www.cnblogs.com/jedi1995/p/11320357.html

但是我并没有在nginx官网中找到官方描述(可能仅仅是因为我没找到)

问题反思

现在整个问题流程就很清晰了

  1. 发送方请求了一个少了最后/的请求
  2. nginx返回301状态码,并返回补全/的重定向连接
  3. 发送方因为301状态码,将请求改为get请求,并按照新连接发送
  4. nginx获得新的连接,完成匹配,并转发
  5. 服务获得get请求

我在想这是不是一个bug?如果nginx返回采用308状态码是不是就能够避免这个问题了?文章来源地址https://www.toymoban.com/news/detail-402209.html

到了这里,关于Nginx转发post请求变get请求的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • nginx请求转发webSocket

    原由 1.我有一个socket服务,用ip访问是成功的,但是老板说用这个不行,要用nginx请求转发,转发内网地址到某个域名 2.但是我改成了指定域名后失败, 因为我没有配置 nginx.conf  http的很简单 ,如下(--- 可跳过 ---) server {     listen 80;     server_name *.mynetwork.cn mynetwork.cn;     

    2024年02月01日
    浏览(36)
  • nginx的请求转发配置

    去官网下载nginx后解压 在当前目录打开cmd窗口输入nginx.exe 即可启动服务 若想停止当前服务 输入命令nginx.exe -s stop 快速关闭nginx服务。 (注意使用Ctrl+C或者直接关闭黑窗口是不能停止服务的 ) 使用Nginx来完成请求的转发 负责分配请求的转发到的服务其他命令: nginx -s quit 优雅的

    2024年02月13日
    浏览(43)
  • 使用nginx实现请求转发的功能

    nginx(反向代理服务器)主要功能 请求转发 负载均衡 动静分离 配置nginx,实现请求转发的功能 找到nginx配置文件 在nginx.conf中进行配置 (1)最好将nginx默认的80端口修改为81 (2)配置nginx转发规则 (3)具体配置 修改config/dev.env.js中的BASE_API 重启nginx

    2024年02月11日
    浏览(76)
  • nginx负载转发源请求http/https:X-Forwarded-Proto及nginx中的转发报头

    今天在排查服务器的问题时最后定位到服务器因为经过了运维这一层的处理,转发过来的请求不管用户请求的是https还是http,我们的proxy服务器收到的都是80端口上的http。于是联系相关部门了解有没有现成的可用的这样一个字段来获得这个值。公司用的也是标准报头,即X-Fo

    2024年02月16日
    浏览(56)
  • nginx 如何将 https 请求转发到 http

    网站之前是 https 的,通过 nginx 设置好了,现在不想用 https 了,但发散到外界的一些网址还是 https 的,此时只能通过 nginx 去转发 https 请求到 http 才能实现之前的链接能正常访问。 具体设置如下: https 的其它设置不需要动,只需要在 server 字段添加一条:

    2024年02月11日
    浏览(57)
  • Nginx接收Http协议请求转发使用Https协议

    公司使用阿里的apigateway,规定不太友好,同是SIT环境,A系统的SIT1环境居然不能调用B系统的SIT2环境的接口。因为各个系统之间部署的SIT环境数量不同A系统可能只有1套,B系统可能有8套,这样的话,可能会随时切换调用B系统的环境,管理员不允许,于是想着用Nginx做下转发。

    2024年02月08日
    浏览(63)
  • tengine/nginx https请求 转发 http upstream

    当前的互联网应用基本都要支持https协议,而当浏览器头通过https协议将请求发到到负责负载的nginx后,会由当前nginx再以http协议向后端upstream进行请求,之所以这么做是因为https协议的安全性也带来的额外的性能消耗。而源端基本都是在一个内网里面的,对于通讯协议的安全性

    2024年01月23日
    浏览(43)
  • Nginx将请求转发至后端应该怎么做?

    在nginx的配置文件中新建一个server监听前端部署的端口 然后在server中添加一个location,就是把访问路径指向前端项目打包后的地址 在部署前后端分离项目时,通常都要使用nginx把前端的请求转发到后端的接口上去,这就要配置nginx的proxy_pass功能。 代理转发需要注意的事儿 在

    2024年02月04日
    浏览(47)
  • 解决nginx 部署前端post请求405 not allowed

    问题第一次部署前端,将vue生成的dist 文件部署到nginx后,进入页面后post请求查询数据时,出现405 not allowed,经查阅发现,nginx 静态资源访问不支持post请求。 解决方案

    2024年02月11日
    浏览(36)
  • Netty服务如何使用Nginx代理转发请求并获得原始IP

    Nginx启用stream模块,示例如下: 示例,代理远端8080的netty服务。 注意,获得原始客户端的IP关键配置在于: proxy_protocol on; 这一行配置。如果不配置,在netty服务端是无法获得原始客户端ip,但是配置上之后,netty需要调整代码。 代理http协议的时候,可以通过增加X-Forwarded-Fo

    2024年02月06日
    浏览(49)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包