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(发邮件时,请将#更换为@)进行举报,并提供相关证据,一经查实,本站将立刻删除涉嫌侵权内容。