微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

Spring mvc 接收json对象

本文通过代码实例介绍spring mvc 接收json数据的方法,具体详情如下所示:

接收JSON

使用 @RequestBody 注解前台只需要向 Controller 提交一段符合格式的 JSON,Spring 会自动将其拼装成 bean。

1)在上面的项目中使用第一种方式处理返回JSON的基础上,增加如下方法

Java代码

rush:java;"> @RequestMapping(value="/add",method=RequestMethod.POST,headers = {"content-type=application/json","content-type=application/xml"}) @ResponseBody public Object addUser(@RequestBody User user) { System.out.println(user.getName() + " " + user.getAge()); return new HashMap().put("success","true"); }

这里的POJO如下:

Java代码

rush:java;"> public class User { private String name; private String age; //getter setter }

2)而在前台,我们可以用 jQuery 来处理 JSON。从这里,我得到了一个 jQuery 的插件,可以将一个表单的数据返回成JSON对象:

Js代码

rush:js;"> $.fn.serializeObject = function(){ var o = {}; var a = this.serializeArray(); $.each(a,function(){ if (o[this.name]) { if (!o[this.name].push) { o[this.name] = [o[this.name]]; } o[this.name].push(this.value || ''); } else { o[this.name] = this.value || ''; } }); return o; };

以下是使用 jQuery 接收、发送 JSON 的代码

Js代码

rush:js;"> $(document).ready(function(){ jQuery.ajax({ type: 'GET',contentType: 'application/json',url: 'jsonFeed.do',dataType: 'json',success: function(data){ if (data && data.status == "0") { $.each(data.data,function(i,item){ $('#info').append("姓名:" + item.name +",年龄:" +item.age); }); } },error: function(){ alert("error") } }); $("#submit").click(function(){ var jsonuserinfo = $.toJSON($('#form').serializeObject()); jQuery.ajax({ type: 'POST',url: 'add.do',data: jsonuserinfo,success: function(data){ alert("新增成功!"); },error: function(){ alert("error") } }); }); });

但是似乎用Spring这套东西真是个麻烦的事情,相对Jersey对RESTful的实现来看,确实有很多不简洁的地方。

以上所述是本文给大家分享的Spring mvc 接收json数据的相关资料,希望大家喜欢。

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 [email protected] 举报,一经查实,本站将立刻删除。

相关推荐