Http 405问题 #2018-09-12

2018-09-12  本文已影响0人  grr1314

什么是http是405问题

用来访问本页面的http方法不被允许

为什么会出现405问题

在请求资源的时候没有设置正确的MIME类型,说白了就是一个Post接口使用了Get方法请求或者是一个Get接口使用了Post方法

场景

在公司变更主体之前,使用新的域名通过代理服务器访问服务器,Get请求没有问题Post请求报405。405问题本身的意义很简单,上面也做了介绍那么也就是说走了代理之后Post请求变成了Get请求,这是为什么呢?通过运维同事那里得知使用的是Nginx代理,并且我得到了一句很关键的话“Nginx post 参数丢失”,另外查看Nginx日志发现用POST方法请求一次日志里打印了POST和GET。

什么是Nginx##

https://www.cnblogs.com/nbkyzms/p/5174089.html

重定向

301 Moved Permanently###

永久重定向。该状态码表示请求的资源已被分配到新的URI。假如说用一个旧的URI去请求资源就会报301

302 Found###

临时重定向。该状态码表示请求资源已经被分配到了新的URI,希望用户本次使用新的URI访问。

303 See Other###

该状态码表示由于请求对应的资源存在着另一个URI,应该使用GET方法定向请求资源。

备注:###

301和302相似,但是302代表的不是资源永久移动,只是临时的。也就是说资源对应的URI将来还有可能移动。303和302有相同的功能,但是303明确的表示客户端应该用GET方法获取资源!

原因

客户端(手机)发送POST请求到Nginx代理服务器,Nginx代理服务器进行重定向给客户端报302状态码。之后客户端再次发送请求但是由原来的POST转成了GET,当请求到了服务器以后就自然会报405状态!至于为什么POST会转成GET,以下摘录一段《图解Http》一书第4章第3.3小节的一段原话

当301、302、303响应状态吗返回时,几乎所有的浏览器都会把POST改成GET,并删除请求报文内的主体,之后请求会再次自动发送。
301、302标准是禁止POST方法改变成GET方法的,但实际使用时大家都会这么做。

解决办法

在Nginx将客户端发送过来的请求做拦截,然后判断是GET请求还是POST。如果是GET请求那么Nginx代理服务器将请求直接转发给服务器,如果是POST请求则在Nginx的proxy_pass命令,proxy_pass配置可以保证POST参数不丢失。

参考文章

《图解HTTP》

https://www.cnblogs.com/nbkyzms/p/5174089.html

https://www.cnblogs.com/cswuyg/p/3871976.html

http://www.alanflavell.org.uk/www/post-redirect.html

上一篇下一篇

猜你喜欢

热点阅读