问题背景:
我要在一个表单里同时一次性提交多名乘客的个人信息到SpringMVC,前端HTML和SpringMVC Controller里该如何处理?

第1种方法:表单提交,以字段数组接收;

第2种方法:表单提交,以BeanListModel接收;

第3种方法:将Json对象序列化成Json字符串提交,以List接收;

第4种方法:将表单对象序列化成Json字符串提交,以List接收;
第4种方法其实是第3种方法的升级,就是将表单转成Json对象,再转成Json字符串提交;
然而,第4种方法还不支持含有多选控件表单的提交,故应该还有第5种加强版的方法。

以上4种方法都共用同一个User实体类,代码如下:

public class User {

privateInteger id;

privateString name;

privateString pwd;

@Override

publicString toString() {

return "User{" +

"id=" + id +

", name='" + name + '\''+

", pwd='" + pwd+ '\'' +

'}';

}

//.......后面还有getter、setter方法,省略了

}


第1种方法:表单提交,以字段数组接收
HTML代码如下:

<formaction="/user/submitUserList_1" method="post">

ID:<input type="text" name="id"><br/>

Username:<input type="text" name="name"><br/>

Password:<input type="text" name="pwd"><br/><br/>

ID:<input type="text" name="id"><br/>

Username:<input type="text" name="name"><br/>

Password:<input type="text" name="pwd"><br/><br/>

<input type="submit" value="submit">

</form>

Java代码如下:

@RequestMapping(value = "/submitUserList_1", method={RequestMethod.POST})

@ResponseBody

public String submitUserList_1(HttpServletResponse response,Integer[] id,String[] name, String[] pwd)

throws Exception{

String result = "";

if(id == null || id.length <= 0){ return "No any ID.中文"; }

List<User> userList = new ArrayList<User>();

for (int i = 0; i < id.length; i++ ) {

User user = new User();

user.setId(id[i]);

user.setName(name[i]);

user.setPwd(pwd[i]);

userList.add(user);

}

result = this.showUserList(userList);

return result;

}


第2种方法:表单提交,以BeanListModel接收
HTML代码如下:

<formaction="/user/submitUserList_2" method="post">

ID:<input type="text" name="users[0].id"><br/>

Username:<input type="text" name="users[0].name"><br/>

Password:<input type="text"name="users[0].pwd"><br/><br/>

ID:<input type="text" name="users[2].id"><br/>

Username:<input type="text" name="users[2].name"><br/>

Password:<input type="text" name="users[2].pwd"><br/><br/>

<input type="submit" value="Submit">

</form>

Java代码:
除了刚才公用的User类,还要封装一个User的容器类UserModel:

public class UserModel {

privateList<User> users;

publicList<User> getUsers() {

return users;

}

publicvoid setUsers(List<User> users) {

this.users = users;

}

publicUserModel(List<User> users) {

super();

this.users = users;

}

publicUserModel() {

super();

}

}

SpringMVC Controller方法:

@RequestMapping(value= "/submitUserList_2", method ={RequestMethod.POST})

@ResponseBody

publicString submitUserList_2(UserModel users)

throws Exception{

String result = "";

List<User> userList = users.getUsers();

if(userList == null || userList.size() <= 0){ return "No any ID.中文"; }

result = this.showUserList(userList);

return result;

}


第3种方法:将Json对象序列化成Json字符串提交,以List接收
HTML代码:

<head>

<title>submitUserList_3</title>

<metahttp-equiv="content-type" content="text/html;charset=utf-8">

<scriptlanguage="JavaScript" src="/js/jquery.min.js" ></script>

<scriptlanguage="JavaScript" src="/js/jquery.json.min.js"></script>

<scripttype="text/javascript" language="JavaScript">

function submitUserList_3() {alert("ok");

var customerArray = new Array();

customerArray.push({id: "1", name: "李四",pwd: "123"});

customerArray.push({id: "2", name: "张三",pwd: "332"});

$.ajax({

url: "/user/submitUserList_3",

type: "POST",

contentType : 'application/json;charset=utf-8',//设置请求头信息

dataType:"json",

//data:JSON.stringify(customerArray),    //将Json对象序列化成Json字符串,JSON.stringify()原生态方法

data:$.toJSON(customerArray),            //将Json对象序列化成Json字符串,toJSON()需要引用jquery.json.min.js

success: function(data){

alert(data);

},

error: function(res){

alert(res.responseText);

}

});

}

</script>

</head>

<body>

<h1>submitUserList_3</h1>

<inputid="submit" type="button" value="Submit" onclick="submitUserList_3();">

</body>

Java代码:

@RequestMapping(value= "/submitUserList_3", method ={RequestMethod.POST})

@ResponseBody

publicString submitUserList_3(@RequestBody List<User> users)

throws Exception{

String result = "";

if(users == null || users.size() <= 0){ return "No any ID.中文"; }

result = this.showUserList(users);

return result;

}


第4种方法:将表单对象序列化成Json字符串提交,以List接收
HTML代码:

<!DOCTYPE HTML PUBLIC "-//W3C//DTDHTML 4.01 Transitional//EN"

"http://www.w3.org/TR/html4/loose.dtd">

<html>

<head>

<title>submitUserList_4</title>

<metahttp-equiv="content-type" content="text/html;charset=utf-8">

<scriptlanguage="JavaScript" src="/js/jquery.min.js" ></script>

<scripttype="text/javascript" language="JavaScript">

//将表单序列化成json格式的数据(但不适用于含有控件的表单,例如复选框、多选的select)

(function($){

$.fn.serializeJson = function(){

var jsonData1 = {};

var serializeArray = this.serializeArray();

// 先转换成{"id":["12","14"], "name":["aaa","bbb"],"pwd":["pwd1","pwd2"]}这种形式

$(serializeArray).each(function() {

if (jsonData1[this.name]) {

if($.isArray(jsonData1[this.name])) {

jsonData1[this.name].push(this.value);

} else {

jsonData1[this.name]= [jsonData1[this.name], this.value];

}

} else {

jsonData1[this.name] = this.value;

}

});

// 再转成[{"id":"12", "name": "aaa","pwd":"pwd1"},{"id": "14","name": "bb", "pwd":"pwd2"}]的形式

var vCount = 0;

// 计算json内部的数组最大长度

for(var item in jsonData1){

var tmp =$.isArray(jsonData1[item]) ? jsonData1[item].length : 1;

vCount = (tmp > vCount)? tmp : vCount;

}

if(vCount > 1) {

var jsonData2 = new Array();

for(var i = 0; i <vCount; i++){

var jsonObj = {};

for(var item in jsonData1){

jsonObj[item] =jsonData1[item][i];

}

jsonData2.push(jsonObj);

}

return JSON.stringify(jsonData2);

}else{

return "[" + JSON.stringify(jsonData1)+ "]";

}

};

})(jQuery);

function submitUserList_4() {alert("ok");

var jsonStr = $("#form1").serializeJson();

//console.log("jsonStr:\r\n" + jsonStr);

//alert(jsonStr);

$.ajax({

url: "/user/submitUserList_4",

type: "POST",

contentType : 'application/json;charset=utf-8',//设置请求头信息

dataType:"json",

data: jsonStr,

success: function(data){

alert(data);

},

error: function(res){

alert(res.responseText);

}

});

}

</script>

</head>

<body>

<h1>submitUserList_4</h1>

<formid="form1">

ID:<input type="text" name="id"><br/>

Username:<input type="text" name="name"><br/>

Password:<input type="text" name="pwd"><br/><br/>

ID:<input type="text" name="id"><br/>

Username:<input type="text" name="name"><br/>

Password:<input type="text" name="pwd"><br/><br/>

<input type="button" value="submit" onclick="submitUserList_4();">

</form>

</body>

</html>

Java代码:

@RequestMapping(value= "/submitUserList_4", method ={RequestMethod.POST})

@ResponseBody

publicString submitUserList_4(@RequestBody List<User> users)

throws Exception{

String result = "";

if(users == null || users.size() <= 0){ return "No any ID.中文"; }

result = this.showUserList(users);

return result;

}

总结:
第1、2种方法其实都有一个共同的BUG:假如提交三条记录时,前面两条记录的某些字段不填值的话,在SpringMVC里接收不准确了。而且,每2种方法在HMTL中需要给name属性添加[下标],如果下标有跨度的话(比如第一组控件下标是0,第二组下标是2),那么SpringMVC里其实的是0到2三个对象的,默认下标是1的那个对象全为null值。
第3、4种方法最实用。

以上方法参考自以下URL:
http://www.cnblogs.com/wsw0515/p/3582627.html
http://www.oschina.net/question/917732_106601
http://jxd-zxf.iteye.com/blog/2072300
http://www.tashan10.com/jquery-jiang-biao-dan-xu-lie-hua-wei-jsondui-xiang/

4种方法让SpringMVC接收多个对象(转:http://blog.csdn.net/lutinghuan/article/details/46820023)的更多相关文章

  1. springboot项目--传入参数校验-----SpringBoot开发详解(五)--Controller接收参数以及参数校验----https://blog.csdn.net/qq_31001665/article/details/71075743

    https://blog.csdn.net/qq_31001665/article/details/71075743 springboot项目--传入参数校验-----SpringBoot开发详解(五 ...

  2. 4种方法让SpringMVC接收多个对象 <转>

    问题背景: 我要在一个表单里同时一次性提交多名乘客的个人信息到SpringMVC,前端HTML和SpringMVC Controller里该如何处理? 第1种方法:表单提交,以字段数组接收: 第2种方 ...

  3. 4种方法让SpringMVC接收多个对象

    问题背景: 我要在一个表单里同一时候一次性提交多名乘客的个人信息到SpringMVC,前端HTML和SpringMVC Controller里该怎样处理? 第1种方法:表单提交,以字段数组接收: 第2 ...

  4. Golang拼接字符串的5种方法及其效率_Chrispink-CSDN博客_golang 字符串拼接效率 https://blog.csdn.net/m0_37422289/article/details/103362740

    Different ways to concatenate two strings in Golang - GeeksforGeeks https://www.geeksforgeeks.org/di ...

  5. 单点登录的三种实现方式 转自: https://blog.csdn.net/python_tty/article/details/53113612

    单点登录SSO(Single Sign On)说得简单点就是在一个多系统共存的环境下,用户在一处登录后,就不用在其他系统中登录,也就是用户的一次登录能得到其他所有系统的信任.单点登录在大型网站里使用得 ...

  6. python 使用函数名的字符串调用函数(4种方法)_black-heart的专栏-CSDN博客 https://blog.csdn.net/mrqingyu/article/details/84403924

    funcs = ['fetch_data_' + i for i in ( 'activities', 'banners', 'server_list')]# from operator import ...

  7. spring加载hibernate映射文件的几种方式。转自:http://blog.csdn.net/huiwenjie168/article/details/7013618

    在Spring的applicationContext.xml中配置映射文件,通常是在<sessionFactory>这个Bean实例中进行的,若配置的映射文件较少时,可以用sessionF ...

  8. 快速掌握 Android Studio 中 Gradle 的使用方法 [转http://blog.csdn.net/feelang/article/details/41783317]

    Gradle是可以用于Android开发的新一代的 Build System, 也是 Android Studio默认的build工具. Gradle脚本是基于一种JVM语言 -- Groovy,再加 ...

  9. <转载> 22种代码味道(Martin Fowler与Kent Beck) http://blog.csdn.net/lovelion/article/details/9301691

    Martin Fowler在Refactoring: Improving the Design of Existing Code(中译名:<重构——改善既有代码的设计>)一书中与Kent ...

随机推荐

  1. linux下的静态库与动态库详解

    静态库 先说说我们为什么需要库? 当有些代码我们大量会在程序中使用比如(scanf,printf等)这些函数我们需要在程序中频繁使用,于是我们就把这些代码编译为库文件,在需要使用时我们直接链接即可. ...

  2. Docker 编辑网络配置文件

    Docker 1.2.0 开始支持在运行中的容器里编辑 /etc/hosts, /etc/hostname 和 /etc/resolve.conf 文件. 但是这些修改是临时的,只在运行的容器中保留, ...

  3. ROS机器人程序设计(原书第2版)补充资料 kinetic

    Effective Robotics Programming with ROS Third Edition Find out everything you need to know to build ...

  4. Redis之(二)数据类型及存储结构

    Redis支持五中数据类型:String(字符串),Hash(哈希),List(列表),Set(集合)及zset(sortedset:有序集合). Redis定义了丰富的原语命令,可以直接与Redis ...

  5. Programming In Scala笔记-第二、三章

    本系列博客以<Programming in Scala 2nd Edition>为主,围绕其中的代码片段进行学习和分析. 本文主要梳理Chapter2和Chapter3中涉及到的主要概念. ...

  6. eclipse properties 插件

    eclipse properties 插件安装,分享牛,分享牛原创.eclipse properties 编辑器使用. eclipse因为是原生的,可能集成的插件不多,需要自己手动安装.eclipse ...

  7. TextView + Spanned实现图文混排以及图片点击交互

    最近要实现图文混排的需求,webview过大,所以想到了用SpannableStringBuilder来实现. 不过参考了大量国内文章,大多数是教你如何实现图文混排,并没有提及图片点击交互的.有翻阅了 ...

  8. 用Codility测试你的编码能力

    没有宏观的架构设计,没有特定的框架语言.在Codility提出的一些小问题上,用最纯粹的方式测试你最基本的编码能力. Codility第一课:算法复杂度 各种算法书的开篇大多是算法分析,而复杂度(co ...

  9. Spark发展现状与战线

    前言 现今Spark正是风头正劲时,Spark本是UCBerkeley的AMPLab诞生的项目,后来捐赠给了Apache来管理源码和后续发展.今年从Apache孵化器终于孵化出了1.0版本.其对大数据 ...

  10. ORACLE数据库学习之SQL性能优化详解

                                                                                    Oracle  sql 性能优化调整 ...