springMVC参数绑定JSON类型的数据
需求就是:
现在保存一个Student,并且保存Student的friend,一个student会有多个朋友,这里要传递到后台的参数是:
var friends = new Array();
var o1 = {
"family": "大宅门",
"otherName": "lisi",
"desc": "亲密无间的好朋友"
} var o2 = {
"family": "军大院",
"otherName": "wangwu",
"desc": "关系一般"
} friends.push(o1);
friends.push(o2); //要传递的参数:id=1 name=zhangsan age=10是要保存的student信息,并且friends是student的朋友信息;
data:{
"id": 1,
"name": "zhangsan",
"age": 10,
"friends":friends
},
一、包装类型来接收JSON类型的传参:
方法一其实就是 springMVC学习(11)-json数据交互和RESTful支持 中接收json数据;只不过包装了另一个po
前台代码,ajax传递数据:
<input type="button" onclick="saveFriend()" value="保存friend" />
<script type="text/javascript">
/**
* 保存朋友
*/
function saveFriend(){
var friends = new Array();
var o1 = {
"family": "大宅门",
"otherName": "lisi",
"desc": "亲密无间的好朋友"
} var o2 = {
"family": "军大院",
"otherName": "wangwu",
"desc": "关系一般"
} friends.push(o1);
friends.push(o2); //要发送的参数
var params = {
"id": 1,
"name": "zhangsan",
"age": 10,
"friends":friends
}; $.ajax({
type: 'post',
url: '${pageContext.request.contextPath }/saveStudent',
contentType:'application/json;charset=utf-8',
dataType: 'json',
data: JSON.stringify(params),
success: function(data){
console.log(data);
}
});
}
</script>
Controller中接受这个参数:
/**
* 保存朋友
*/
@RequestMapping("/saveStudent")
@ResponseBody
public void saveStudent(@RequestBody StudendAndFriend studendAndFriend){
System.out.println("接收参数friends--->> " + studendAndFriend);
}
接收参数的包装类:
StudendAndFriend.java:
package com.cy.po; import java.util.List; /**
* 接收参数包装类
* @author chengyu
*
*/
public class StudendAndFriend {
private int id;
private String name;
private int age;
private List<Friend> friends; public int getId() {
return id;
}
public void setId(int id) {
this.id = id;
}
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
public int getAge() {
return age;
}
public void setAge(int age) {
this.age = age;
}
public List<Friend> getFriends() {
return friends;
}
public void setFriends(List<Friend> friends) {
this.friends = friends;
} }
Friend.java:
package com.cy.po;
public class Friend {
private String family;
private String otherName;
private String desc;
public String getFamily() {
return family;
}
public void setFamily(String family) {
this.family = family;
}
public String getOtherName() {
return otherName;
}
public void setOtherName(String otherName) {
this.otherName = otherName;
}
public String getDesc() {
return desc;
}
public void setDesc(String desc) {
this.desc = desc;
}
@Override
public String toString() {
return "Friend [family=" + family + ", otherName=" + otherName
+ ", desc=" + desc + "]";
}
}
后台成功接收参:

注意点:
ajax传参:
contentType:'application/json;charset=utf-8'; //contentType为application/json
data: JSON.stringify(params), //传的是字符串;
方法二、
传递String类型的json字符串过来,后台接收后,进行JSONArray解析成对应的List<Object>;
这里使用fastjson-1.2.2.jar包来对json字符串转化为javabean类型;
前端发送请求:
<input type="button" onclick="saveFriend2()" value="保存friend2" />
<script type="text/javascript">
/**
* 保存朋友2
*/
function saveFriend2(){
var friends = new Array();
var o1 = {
"family": "大宅门",
"otherName": "lisi",
"desc": "亲密无间的好朋友"
} var o2 = {
"family": "军大院",
"otherName": "wangwu",
"desc": "关系一般"
} friends.push(o1);
friends.push(o2); friends = JSON.stringify(friends); $.ajax({
type: 'post',
url: '${pageContext.request.contextPath }/saveStudent2',
dataType: 'json',
data: {
"id": 1,
"name": "zhangsan",
"age": 10,
"friends":friends
},
success: function(data){
console.log(data);
}
});
}
</script>
Controller接收这个参数:
//用的是fastjson
import com.alibaba.fastjson.JSONArray;
import com.cy.po.Friend;
/**
* 保存朋友2
*/
@RequestMapping("/saveStudent2")
@ResponseBody
public void saveStudent2(int id, String name, int age, String friends){
List<Friend> frientList = JSONArray.parseArray(friends, Friend.class);
System.out.println("接收参数friends--->> " + frientList);
}
可以看到前端发送参数:

controller中经过json解析为javabean:

springMVC参数绑定JSON类型的数据的更多相关文章
- 利用SpringMVC参数绑定实现动态插入数据
javabean代码:public class User { private String firstName; private String lastName; public String getF ...
- springmvc:请求参数绑定集合类型
一.请求参数绑定实体类 domain: private String username; private String password; private Double money; private ...
- [转载]SpringBoot系列: SpringMVC 参数绑定注解解析
本文转载自 https://www.cnblogs.com/morethink/p/8028664.html, 作者写得非常好, 致谢! SpringMVC 参数绑定注解解析 本文介绍了用于参数绑 ...
- 一篇文章搞定SpringMVC参数绑定
SpringMVC参数绑定,简单来说就是将客户端请求的key/value数据绑定到controller方法的形参上,然后就可以在controller中使用该参数了 下面通过5个常用的注解演示下如何进行 ...
- spring-mvc---Controller参数绑定的类型
Controller参数绑定的类型 Controller的绑定参数类型6种.没有参数(系统默认类型):简单类型(Intager,Double)等:pojo类(对象):数组:集合:HashMap等. 我 ...
- SpringMVC参数绑定,这篇就够了!
SpringMVC参数绑定,简单来说就是将客户端请求的key/value数据绑定到controller方法的形参上,然后就可以在controller中使用该参数了 下面通过5个常用的注解演示下如何进行 ...
- SpringMVC参数绑定(未完待续)
1. Strut2与SpringMVC接收请求参数的区别 Struts2通过action类的成员变量接收SpringMVC通过controller方法的形参接收 2. SpringMVC参数绑定流程 ...
- SpringMvc参数绑定出现乱码解决方法
在SpringMvc参数绑定过程中出现乱码的解决方法 1.post参数乱码的解决方法 在web.xml中添加过滤器 <!-- 过滤器 处理post乱码 --> <filter> ...
- 存在日期类型的JSON数据,进行SpringMVC参数绑定时存在的问题和解决方案
这篇文章已经过时了. 请参考比较合适的前后端交互方式. 首先是发送AJAX请求的html页面 <!DOCTYPE html> <html> <head> <m ...
随机推荐
- poj2895
题解: splay,维护当前第k大 并查集维护当前集合 合并x,y时,del(num[x]),del(num[y]),insert(num[x]+num[y]) 代码: #include<cst ...
- 关于list集合存储null的问题
工作中,遇到list集合存储null的问题,不确定list能否存储null值.于是写一些demo测试list,set,table,及map存储null的问题. 1.list之arraylist pub ...
- Saiku_学习_01_saiku安装与运行
一.下载saiku 1.下载地址 官网:https://community.meteorite.bi/ 2.解压后文件结构 3.ROOT和saiku 在tomcat/webapp 下有两个web应用, ...
- vsftpd配置虚拟用户为登录用户02
1.安装vsftpd 安装依赖包: yum -y install pam pam-devel db4 de4-devel db4-uitls db4-tcl 新建vsftpd系统用户: #建立Vsft ...
- SharePoint Infopath表单服务-PowerShell
1. 激活可浏览的表单模板 Set-SPInfoPathFormsService -AllowUserFormBrowserEnabling $true -AllowUserFormBrowserRe ...
- IOS工作中的问题(转)
1.UITableView的scrollDelegate问题 下午遇到一个奇怪的问题,之前都没有注意过,由于A VC中要实现tableView和其他View位置的联动,所以实现了tableView的d ...
- JDK中Integer类的进制转换实现
JDK中关于Integer类的进制转换方法很精巧,具体实现如下: final static char[] digits = { '0' , '1' , '2' , '3' , '4' , '5' , ...
- L2-009. 抢红包
没有人没抢过红包吧…… 这里给出N个人之间互相发红包.抢红包的记录,请你统计一下他们抢红包的收获. 输入格式: 输入第一行给出一个正整数N(<= 104),即参与发红包和抢红包的总人数,则这些人 ...
- jQuery自动完成点击html元素
/************************************************************************** * jQuery自动完成点击html元素 * 声 ...
- 安卓手机文件管理器简单横向评比 - imsoft.cnblogs
X-plore文件管理器 个人评价:安卓手机上管理文件的神器,所有文件一览无余,加上自己对软件常用功能的配置,管理文件无比方便.(本人一直使用) Solid文件管理器 个人评价:用户体验真的很 ...