您好,欢迎来到红游网。
搜索
您的当前位置:首页在springmvc返回json数据到ajax报错应该如何处理

在springmvc返回json数据到ajax报错应该如何处理

来源:红游网


这次给大家带来在spring mvc 返回json数据到ajax报错应该如何处理,处理在spring mvc返回json数据到ajax报错的注意事项有哪些,下面就是实战案例,一起来看一下。

最近使用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可以解析到,不会报错。

相信看了本文案例你已经掌握了方法,更多精彩请关注Gxl网其它相关文章!

推荐阅读:

ajax的三级联动菜单栏如何实现

ajax数据处理步骤详解(附代码)

Copyright © 2019- redlover.cn 版权所有

违法及侵权请联系:TEL:199 18 7713 E-MAIL:2724546146@qq.com

本站由北京市万商天勤律师事务所王兴未律师提供法律服务