常见踩坑案例(二)-Request method 'POST' not supported
一 前言
最近涉及到与前后端的数据对接,按道理来说没一点压力结果被一前端童鞋带坑里去了(不过也是很久没写过这种前后端分离进行联调的事情了,如果是一个人全套弄的话就不会出现下面问题)。
二 Request method 'POST' not supported
进入正文,跟前端进行数据联调时,别人联调都正常,到联调我的接口(进行数据获取)就出现了问题。
下面进行异常场景还原(后端环境:Spring MVC4.0.5):
1、前端访问我这边的接口抛出错误码:405 Method not allowed 。当时就感觉奇怪,我自己用postman都能调通啊,为什么你那边不能允许访问呢。看到这个错误码,于是我就抛出两个问题给他:
- 你是用post请求吗?
- 你请求的content-type是application/json吗?
然后他毫不犹豫的说都是。
2、于是我看下后端请求的日志,SpringMVC日志提示:“[org.springframework.web.servlet.PageNotFound] >>> Request method 'POST' not supported” 。
提示这个错误,我就纳闷了。条件反射让我想起是不是在@RequestMapping中Method 没有指定为post? 其实我指定了post方法的,这个肯定排除了。
@RequestMapping(value = "/home/test", method = RequestMethod.POST)
@ResponseBody
public Object test(@RequestBody UserEntity userEntity) { return "1234";
}
难道真的是我后端的问题?查了网上很多问题一堆不靠谱:(,一直沉迷于Request method 'POST' not supported这个信息无法自拔,难道这配置不支持post方法?。于是就尝试了以下手段:
a、ResourceHttpRequestHandler在springMVC配置文件配置强制支持post方法。可想而知,ResourceHttpRequestHandler针对静态资源的获取及其缓存设置。很明显不符合场景,试了也是白试。如果你这种场景请参考这里获取对你有帮助:https://stackoverflow.com/questions/15588001/spring-not-accept-post-request-under-mvcresources-how-to-fix-that。
b、尝试将RequestMapping中请求的方法改成get,前端也用get请求,并没有用。
3、尝试了上面方法后无果,有位前辈说不妨你跟踪下SpringMVC中日志代码。
第一步:查看PageNotFound是否存在对应的类(这一步其实一出现我就查看是没有的),怎么验证它是否存在呢?很简单:在代码中输入它看是否有对应的引用包。

第二步:第一步最直接的入口失败,于是想到了SpringMVC的核心Servlet:DispatcherServlet, 而它的核心方法则是:doDispatch,于是在方法中进行断点调试找到出错原因。经过调试后,终于发现问题所在,发现在解析json是实体的属性出错,如下图:

上述案例是说不能解析namqe这个属性,而我UserEntity对象中的属性是name,所以解析类就抛出异常(至于在哪一步解析出错,这就不一一说了)。
经过上面一步一步的探索终于找到问题的所在:原来是前端童鞋传json的时候,把参数名称弄错了。
4、拓展
虽然问题解决了,但是为啥Spring MVC 为啥抛出那样的日志,而不是具体的错误信息呢?如果是具体的错误信息那不简单明了嘛,也不至于花了这么时间去定位问题所在。于是继续调试看看这个错误信息为什么被转换了?看上面图的971行,最终结果都会进入到这个方法processDispatchResult,而它的第一步就是检测是否有异常,如果有异常则先处理异常:

里面流程也不一一显示了,直接跳到具体解析异常的类:DefaultHandlerExceptionResolver,我们看看这个类中有什么又是怎么处理异常的。

看到上图就应该想到之前提示的日志为什么有[org.springframework.web.servlet.PageNotFound],而找不到对应的类了吧,因为它只是一个日志的Event_Name。
继续跟踪:最终它是走入了HttpMessageNotReadableException类,表示读取信息错误。

继续进入handleHttpMessageNotReadable方法,看到这里就知道结果了,它把原来的错误信息给修改并返回了。

另外这里不是真的返回信息,上面错误信息返回之后还会再次进入DispatcherServlet类重新又走了一遍,所以错误信息又重新判断一次最终进入了下面这个方法,真正的输入日志的地方在这:
所以这个是Spring MVC 4.0.5.RELEASE版本的问题,升级到4.2.0以上就不会抛出这个问题,它会识别能识别的参数继续运行,不会抛出错误。
三 总结
针对这种405错误,总结一下几点:
1、首先第一个需要确认请求方法类型是否一致?
2、请求数据类型 和 接收的数据类型是否一致?
3、请求参数是否正确?
以上都正确的话,然后在具体问题具体分析,一步一步跟踪才是最有效的。
遇上问题要冷静,盲目从医只会浪费时间,需要对症下药,一步一步来。
常见踩坑案例(二)-Request method 'POST' not supported的更多相关文章
- 常见踩坑案例(一) subList引起FULLGC
计划真的赶不上变化,时间过得真快.废话不多说了,今天主要记录之前有同事遇到的一些坑分享出来. 一.封装类的应用会引起NPE异常 对于其他对象的应用,一般在使用之前会判断它是否为空,如果不为空才会使用它 ...
- 微信小程序踩坑之一[wx.request]请求模式
最近在做小程序时,使用wx.request()方法请求时, 当使传输string类型时,一定要声明method请求模式为post,否则会一直报错,而不声明时默认为get, 已填坑 =,= wx.req ...
- Feign发送Get请求时,采用POJO对象传递参数的最终解决方案 Request method 'POST' not supported (附带其余好几个坑)
yml: feign: httpclient: enabled: true properties: #feign feign.httpclient.enabled=true <!-- https ...
- 【Feign调用异常】org.springframework.web.HttpRequestMethodNotSupportedException: Request method 'GET' not supported
一.异常场景描述 明明是post请求,为啥到达服务器后就变成了get请求 2019-05-30 18:07:17.055 [http-nio-10650-exec-4] ERROR c.x.xcaut ...
- Spring boot: Request method 'DELETE' not supported, Request method 'PUT' not supported, Request method 'POST' not supported
GET,POST,PUT,DELETE, Spring都支持,不要怀疑Spring, 一定是前端发送的rest 请求和后端的响应不匹配, 查找原因以及解决办法, 很简单 用chrome打开F12控制台 ...
- org.springframework.web.HttpRequestMethodNotSupportedException: Request method 'PUT' not supported
1:先上控制台报错信息 org.springframework.web.HttpRequestMethodNotSupportedException: Request method 'PUT' not ...
- WARN PageNotFound:208 - Request method 'POST' not supported
在地址栏输入网址访问页面 ,用的是GET方法. 在用ajax接收后台数据,根据返回值进行提示或页面跳转时报:WARN PageNotFound:208 - Request method 'POST' ...
- SpringMVC框架出现 405 request method post not supported 的解决方法
在SpringMVC框架中当使用post请求服务,然后请求成功转到一个静态文件,如html,htm等网页时.页面出现405 request method post not supported错误,只要 ...
- Request method 'POST' not supported错误和解决方法
在使用SpringBoot的时候,在html页面用form表单post提交数据的时候报错: Request method 'POST' not supported 错误解析: 我是用的前端页面是HTM ...
随机推荐
- filebeat向kafka中传输数据报WARN Failed to connect to broker DOMSDev07:9092: dial tcp: lookup DOMSDev07: getaddrinfow: No such host is known.解决方法
打开filebeat客户端所在机器C:\Windows\System32\drivers\etc目录,找到hosts文件 以记事本形式打开,在底部追加 “IP 主机名” 即可
- Mxnet Windows配置
MXNET Windows 编译安装(Python) 本文只记录Mxnet在windows下的编译安装,更多环境配置请移步官方文档:http://mxnet.readthedocs.io/en/lat ...
- hibernate关联关系
hibernate是一个强大的ORM框架,为了使用面向对象的方式管理数据库,hibernate提供了4中关系设置: 1.一对一 (one-to-one) 2.一对多 (one-to-many) 3.多 ...
- JDBC数据库连接技术
[学习笔记]JDBC数据库连接技术(Java Database Connectivity) 一.JDBC简介 Java是通过JDBC技术实现对各种数据库的访问的,JDBC是Java数据库连接技术的简称 ...
- Codeforces 633C Spy Syndrome 2 | Trie树裸题
Codeforces 633C Spy Syndrome 2 | Trie树裸题 一个由许多空格隔开的单词组成的字符串,进行了以下操作:把所有字符变成小写,把每个单词颠倒过来,然后去掉单词间的空格.已 ...
- CodeVs.1036 商务旅行 ( LCA 最近公共祖先 )
CodeVs.1036 商务旅行 ( LCA 最近公共祖先 ) 题意分析 某首都城市的商人要经常到各城镇去做生意,他们按自己的路线去做,目的是为了更好的节约时间. 假设有N个城镇,首都编号为1,商人从 ...
- 第一章:CDib类库的建立
VC++图像处理程序设计(第1版) 杨淑莹 编著 边奠英 主审 第一章 位图基础 Joanna-In-Hdu&Hust 手工打,印象更深刻 使用工具 VS2010 mfc 整本 ...
- 什么是 metadata (元数据)
1. 什么是元数据 任何文件系统中的数据分为数据和元数据.数据是指普通文件中的实际数据,而元数据指用来描述一个文件的特征的系统数据,诸如访问权限.文件拥有者以及文件数据块的分布信息(inode...) ...
- 控制对象的创建方式(禁止创建栈对象or堆对象)和创建的数量
我们知道,C++将内存划分为三个逻辑区域:堆.栈和静态存储区.既然如此,我称位于它们之中的对象分别为堆对象,栈对象以及静态对象.通常情况下,对象创建在堆上还是在栈上,创建多少个,这都是没有限制的.但是 ...
- (转)Tomcat version 7.0 only supports J2EE 1.2, 1.3, 1.4, and Java EE 5 and 6 Web mod
背景:在sts中导入web项目,却不能通过sts中的tomcat来加载该服务,并报出如下错误. “Tomcat version 7.0 only supports J2EE 1.2, 1.3, 1.4 ...