您的位置:首页 > 编程语言 > Java开发

SpringMVC Ajax请求返回404

2016-03-18 23:30 302 查看
Ajax请求返回404常见情况是请求中的URL在Controller层找不到@RequestMapping的URI,还有一种情况是,能正确找到@RequestMapping在Controller中映射的方法,并且方法执行正常,debug时断点打到返回值时需要返回的数据也正常生成,但浏览器控制台却显示xxxx请求404的报错信息。
控制台信息:
2016-01-18 15:22:38:534 org.springframework.web.servlet.handler.AbstractHandlerExceptionResolver.resolveException(AbstractHandlerExceptionResolver.java:132) Resolving exception from
handler [public com.busbooking.common.dto.PageResult<com.busbooking.entity.PlanInfo> com.busbooking.controller.bak.PlanInfoController.planInfoList(com.busbooking.common.dto.QueryParam<com.busbooking.entity.PlanInfo>)]: org.springframework.http.converter.HttpMessageNotWritableException:
Could not write JSON: (was java.lang.NullPointerException) (through reference chain: com.busbooking.common.dto.PageResult["content"]->java.util.ArrayList[1]->com.busbooking.entity.PlanInfo["leSpecialSeats"]); nested exception is com.fasterxml.jackson.databind.JsonMappingException:
(was java.lang.NullPointerException) (through reference chain: com.busbooking.common.dto.PageResult["content"]->java.util.ArrayList[1]->com.busbooking.entity.PlanInfo["leSpecialSeats"])

问题分析:
Ajax请求能正确找到并执行Controller的方法,证明Ajax请求的URL没有错误,问题出在@ResponseBody转换对象时抛错,导致Controller未正常返回浏览器Json数据,一般来讲POJO对象中的私有属性提供其对应的get和set方法,@ResponseBody将返回数据转换成Json对象时通过反射拿到该类的FIleds,再通过get方法获得该属性的值。

如果数据对象中含有getXXX()或isXXX()的方法,然而却没有该属性时,@ResponseBody转换对象可能会抛错,导致没正常返回浏览器,最终表现成404。

解决方法:
1.重命名 getLeSpecialSeats()方法
2.添加属性leSpecialSeats
3.方法上加上@JsonIgnore

出现这种情况时,能很明确改正和发现错误,将Spring的日志级别调成DEBUG,能准确定位转换哪个对象时抛错,然而平时一般将Spring的日志级别设成INFO,日志看不到抛错,就比较难定位问题。
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签:  ajax spring mvc 404