这次给大家带来怎么使用spirngmvc js传递复杂json参数到controller,使用spirngmvc js传递复杂json参数到controller的注意事项有哪些,下面就是实战案例,一起来看一下。
spring mvc在接收集合请求参数时,需要在controller方法的集合参数里前添加@requestbody,而@requestbody默认接收的enctype (mime编码)是application/json,因此发送post请求时需要设置请求报文头信息,否则spring mvc在解析集合请求参数时不会自动的转换成json数据再解析成相应的集合。
以下列举接收list<string>、list<user>、list<map<string,object>>、user[]、user(bean里面包含list)几种较为复杂的集合参数示例:
接收list<string>集合参数:
1、页面js代码:
var idlist = new array();
idlist.push(“1”);
idlist.push(“2”);
idlist.push(“3”);
var isbatch = false;
$.ajax({
type: post,
url: <%=path%>/catalog.do?fn=deletecatalogschemes,
datatype: 'json',
data: {idlist:idlist,isbatch:isbatch},
success: function(data){
…
},
error: function(res){
…
}
});
2、controller方法:
@controller
@requestmapping(/catalog.do)
public class catalogcontroller {
@requestmapping(params = fn=deletecatalogschemes)
@responsebody
public ajaxjson deletecatalogschemes(@requestparam(idlist[]) list<string> idlist,boolean isbatch) {
…
}
}
接收list<user>、user[]集合参数:
1、user实体类:
public class user {
private string name;
private string pwd;
//省略getter/setter
}
2、页面js代码:
var userlist = new array();
userlist.push({name: 李四,pwd: 123});
userlist.push({name: 张三,pwd: 332});
$.ajax({
type: post,
url: <%=path%>/catalog.do?fn=saveusers,
data: json.stringify(userlist),//将对象序列化成json字符串
datatype:json,
contenttype : 'application/json;charset=utf-8', //设置请求头信息
success: function(data){
…
},
error: function(res){
…
}
});
3、controller方法:
@controller
@requestmapping(/catalog.do)
public class catalogcontroller {
@requestmapping(params = fn=saveusers)
@responsebody
public ajaxjson saveusers(@requestbody list<user> userlist) {
…
}
}
如果想要接收user[]数组,只需要把saveusers的参数类型改为@requestbody user[] userarray就行了。
接收list<map<string,object>>集合参数:
1、页面js代码(不需要user对象了):
var userlist = new array();
userlist.push({name: 李四,pwd: 123});
userlist.push({name: 张三,pwd: 332});
$.ajax({
type: post,
url: <%=path%>/catalog.do?fn=saveusers,
data: json.stringify(userlist),//将对象序列化成json字符串
datatype:json,
contenttype : 'application/json;charset=utf-8', //设置请求头信息
success: function(data){
…
},
error: function(res){
…
}
});
2、controller方法:
@controller
@requestmapping(/catalog.do)
public class catalogcontroller {
@requestmapping(params = fn=saveusers)
@responsebody
public ajaxjson saveusers(@requestbody list<map<string,object>> listmap) {
…
}
}
接收user(bean里面包含list)集合参数:
1、user实体类:
public class user {
private string name;
private string pwd;
private list<user> customers;//属于用户的客户群
//省略getter/setter
}
2、页面js代码:
var customerarray = new array();
customerarray.push({name: 李四,pwd: 123});
customerarray.push({name: 张三,pwd: 332});
var user = {};
user.name = 李刚;
user.pwd = 888;
user. customers = customerarray;
$.ajax({
type: post,
url: <%=path%>/catalog.do?fn=saveusers,
data: json.stringify(user),//将对象序列化成json字符串
datatype:json,
contenttype : 'application/json;charset=utf-8', //设置请求头信息
success: function(data){
…
},
error: function(res){
…
}
});
3、controller方法:
@controller
@requestmapping(/catalog.do)
public class catalogcontroller {
@requestmapping(params = fn=saveusers)
@responsebody
public ajaxjson saveusers(@requestbody user user) {
list<user> customers = user.getcustomers();
…
}
}
相信看了本文案例你已经掌握了方法,更多精彩请关注其它相关文章!
推荐阅读:
怎样使用angularjs内$http服务post方法传递json参数
如何利用vue内npm run build根据环境传递不同参数
以上就是怎么使用spirngmvc js传递复杂json参数到controller的详细内容。