spirngmvc js传递复杂json参数到controller的实例
SpringMVC在接收集合请求参数时,需要在Controller方法的集合参数里前添加@RequestBody,而@RequestBody默认接收的enctype(MIME编码)是application/json,因此发送POST请求时需要设置请求报文头信息,否则SpringMVC在解析集合请求参数时不会自动的转换成JSON数据再解析成相应的集合。
以下列举接收List
接收List
1、页面js代码:
varidList=newArray();
idList.push(“1”);
idList.push(“2”);
idList.push(“3”);
varisBatch=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")
publicclassCatalogController{
@RequestMapping(params="fn=deleteCatalogSchemes")
@ResponseBody
publicAjaxJsondeleteCatalogSchemes(@RequestParam("idList[]")ListidList,BooleanisBatch){
…
}
}
接收List
1、User实体类:
publicclassUser{
privateStringname;
privateStringpwd;
//省略getter/setter
}
2、页面js代码:
varuserList=newArray();
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")
publicclassCatalogController{
@RequestMapping(params="fn=saveUsers")
@ResponseBody
publicAjaxJsonsaveUsers(@RequestBodyListuserList){
…
}
}
如果想要接收User[]数组,只需要把saveUsers的参数类型改为@RequestBodyUser[]userArray就行了。
接收List
1、页面js代码(不需要User对象了):
varuserList=newArray();
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")
publicclassCatalogController{
@RequestMapping(params="fn=saveUsers")
@ResponseBody
publicAjaxJsonsaveUsers(@RequestBodyList
接收User(bean里面包含List)集合参数:
1、User实体类:
publicclassUser{
privateStringname;
privateStringpwd;
privateListcustomers;//属于用户的客户群
//省略getter/setter
}
2、页面js代码:
varcustomerArray=newArray();
customerArray.push({name:"李四",pwd:"123"});
customerArray.push({name:"张三",pwd:"332"});
varuser={};
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")
publicclassCatalogController{
@RequestMapping(params="fn=saveUsers")
@ResponseBody
publicAjaxJsonsaveUsers(@RequestBodyUseruser){
Listcustomers=user.getCustomers();
…
}
}
以上这篇spirngmvcjs传递复杂json参数到controller的实例就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持毛票票。
声明:本文内容来源于网络,版权归原作者所有,内容由互联网用户自发贡献自行上传,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任。如果您发现有涉嫌版权的内容,欢迎发送邮件至:czq8825#qq.com(发邮件时,请将#更换为@)进行举报,并提供相关证据,一经查实,本站将立刻删除涉嫌侵权内容。