解决spring mvc 返回json数据到ajax报错parseerror问题
最近使用ajax接收spring mvc传过来的json数据时总是出现parseerror的错误,错误源码如下:
前端:
$.ajax({
type: 'POST',
url: "groupFunctionEdit",
dataType: 'json',
contentType: "application/json",
data: JSON.stringify(functiondata),
success: function(data){
alert('数据加载成功'+data.msg);
},
error: function(xhr, type){
alert('数据加载失败');
console.log(type);
}
后台Controller:
@RequestMapping("/groupFunctionEdit")
public @ResponseBody Object groupFunctionEdit(@RequestBody List<YyGroupFunction> yyGroupFunctionList) throws JsonProcessingException{
return "success";
}
查询资料发现有如下解答:
当使用简单类型即:String这样的类型来接收数据时,不需要使用@RequestBody这个注解。
这里需要使用spring mvc处理json的依赖jar包:jackson.databind.jar
解决办法:
前端不用修改,在后台对需要的数据进行map封装再转化为String类型:
@RequestMapping("/groupFunctionEdit")
public @ResponseBody Object groupFunctionEdit(@RequestBody List<YyGroupFunction> yyGroupFunctionList) throws JsonProcessingException{
Map<String,Object> map = new HashMap<String,Object>();
map.put("msg", "success");
ObjectMapper mapper = new ObjectMapper();
String msg = mapper.writeValueAsString(map);
return msg;
}
这样传到前端的数据变成了:
{"msg":"success"}
再使用jQuery可以解析到,不会报错。
以上所述是小编给大家介绍的解决spring mvc 返回json数据到ajax报错parseerror问题,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对脚本之家网站的支持!
相关文章
使用Yii整合的pjax(pushstate+ajax)实现无刷新加载页面
本篇文章给大家介绍Yii整合pjax(pushstate+ajax)实现无刷新加载页面,小伙伴跟着小编一起学习吧2015-09-09
使用ajax跨域调用springboot框架的api传输文件
这篇文章主要介绍了使用ajax跨域调用springboot框架的api传输文件,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下2019-12-12
AJax 学习笔记二(onreadystatechange的作用)
初次接触onreadystatechange这个事件句柄不知道有何用处,看过一篇文章的介绍之后,终有大致所了解。2010-04-04
ThinkPHP5 通过ajax插入图片并实时显示(完整代码)
这篇文章主要介绍了ThinkPHP5 通过ajax插入图片并实时显示功能,本文给大家分享网站代码,代码简单易懂,非常不错,具有一定的参考借鉴价值,需要的朋友可以参考下2019-12-12


最新评论