`

spring mvc 表单提交

阅读更多

转:http://www.cnblogs.com/luxh/archive/2013/03/14/2960152.html

 

一个普通的表单。

  表单的代码如下:

 

[java] view plaincopy
 
  1. <%@ page language="java" contentType="text/html; charset=UTF-8"  
  2.     pageEncoding="UTF-8"%>  
  3. <!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">  
  4. <html>  
  5. <head>  
  6. <meta http-equiv="Content-Type" content="text/html; charset=UTF-8">  
  7. <title>Add User</title>  
  8.   
  9.   
  10. <script type="text/javascript">  
  11.     //添加用户  
  12.     function addUser() {  
  13.         var form = document.forms[0];  
  14.         form.action = "${pageContext.request.contextPath}/user/addUser1";  
  15.         //form.action = "${pageContext.request.contextPath}/user/addUser2";  
  16.         //form.action = "${pageContext.request.contextPath}/user/addUser3";  
  17.         form.method = "post";  
  18.         form.submit();  
  19.     }  
  20. </script>  
  21.   
  22. </head>  
  23. <body>  
  24.     <form>  
  25.         <table>  
  26.             <tr>  
  27.                 <td>账号</td>  
  28.                 <td>  
  29.                     <input type="text" name="userName">  
  30.                 </td>  
  31.             </tr>  
  32.             <tr>  
  33.                 <td>密码</td>  
  34.                 <td>  
  35.                     <input type="password" name="password">  
  36.                 </td>  
  37.             </tr>  
  38.             <tr>  
  39.                 <td> </td>  
  40.                 <td>  
  41.                     <input type="button" value="提交" onclick="addUser()">  
  42.                 </td>  
  43.             </tr>  
  44.         </table>  
  45.     </form>  
  46. </body>  
  47. </html>  


1、直接把表单的参数写在Controller相应的方法的形参中

 

 

[java] view plaincopy
 
  1. @RequestMapping("/addUser1")  
  2.     public String addUser1(String userName,String password) {  
  3.         System.out.println("userName is:"+userName);  
  4.         System.out.println("password is:"+password);  
  5.         return "/user/success";  
  6.     }  


2、通过HttpServletRequest接收

 

 

[java] view plaincopy
 
  1. @RequestMapping("/addUser2")  
  2.     public String addUser2(HttpServletRequest request) {  
  3.         String userName = request.getParameter("userName");  
  4.         String password = request.getParameter("password");  
  5.         System.out.println("userName is:"+userName);  
  6.         System.out.println("password is:"+password);  
  7.         return "/user/success";  
  8.     }  

 

 

 3、通过一个bean来接收

    1)建立一个和表单中参数对应的bean

[java] view plaincopy
 
  1. public class User {  
  2.       
  3.     private String userName;  
  4.       
  5.     private String password;  
  6.   
  7.     public String getUserName() {  
  8.         return userName;  
  9.     }  
  10.   
  11.     public void setUserName(String userName) {  
  12.         this.userName = userName;  
  13.     }  
  14.   
  15.     public String getPassword() {  
  16.         return password;  
  17.     }  
  18.   
  19.     public void setPassword(String password) {  
  20.         this.password = password;  
  21.     }  
  22. }  


2)用这个bean来封装接收的参数

 

[java] view plaincopy
 
  1. @RequestMapping("/addUser3")  
  2.     public String addUser3(User user) {  
  3.         System.out.println("userName is:"+user.getUserName());  
  4.         System.out.println("password is:"+user.getPassword());  
  5.         return "/user/success";  
  6.     }  


 4、通过json数据接收

 

 

[java] view plaincopy
 
  1. <%@ page language="java" contentType="text/html; charset=UTF-8"  
  2.     pageEncoding="UTF-8"%>  
  3. <!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">  
  4. <html>  
  5. <head>  
  6. <meta http-equiv="Content-Type" content="text/html; charset=UTF-8">  
  7. <title>Add User</title>  
  8.   
  9. <script type="text/javascript" src="${pageContext.request.contextPath}/resource/script/jquery-1.9.1.min.js"></script>  
  10. <script type="text/javascript">  
  11.     $(document).ready(function(){  
  12.         $("#button_submit").click(function(){  
  13.             var name = $("#userName").val();  
  14.             var pass = $("#password").val();  
  15.               
  16.   
  17.             var user = {userName:name,password:pass};//拼装成json格式  
  18.               
  19.             $.ajax({  
  20.                 type:"POST",  
  21.                 url:"${pageContext.request.contextPath}/user/addUser4",  
  22.                 data:user,  
  23.                 success:function(data){  
  24.                     alert("成功");  
  25.                 },  
  26.                 error:function(e) {  
  27.                     alert("出错:"+e);  
  28.                 }  
  29.             });  
  30.         });  
  31.     });  
  32. </script>  
  33.   
  34. </head>  
  35. <body>  
  36.     <form>  
  37.         <table>  
  38.             <tr>  
  39.                 <td>账号</td>  
  40.                 <td>  
  41.                     <input type="text" id="userName" name="userName">  
  42.                 </td>  
  43.             </tr>  
  44.             <tr>  
  45.                 <td>密码</td>  
  46.                 <td>  
  47.                     <input type="password" id="password" name="password">  
  48.                 </td>  
  49.             </tr>  
  50.             <tr>  
  51.                 <td> </td>  
  52.                 <td>  
  53.                     <input type="button" id="button_submit" value="提交">  
  54.                 </td>  
  55.             </tr>  
  56.         </table>  
  57.     </form>  
  58. </body>  
  59. </html>  


依然可以使用bean来接收json数据

 

 

[java] view plaincopy
 
  1. @RequestMapping("/addUser4")  
  2.     public String addUser4(User user) {  
  3.         System.out.println("userName is:"+user.getUserName());  
  4.         System.out.println("password is:"+user.getPassword());  
  5.         return "/user/success";  
  6.     }  

 

 

5、使用jQuery的serializeArray() 方法序列化表单元素

    如果表单元素很多,手工拼装成json数据非常麻烦,可以使用jQuery提供的serializeArray()方法序列化表单元素,返回json数据结构数据。

[java] view plaincopy
 
  1. <%@ page language="java" contentType="text/html; charset=UTF-8"  
  2.     pageEncoding="UTF-8"%>  
  3. <!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">  
  4. <html>  
  5. <head>  
  6. <meta http-equiv="Content-Type" content="text/html; charset=UTF-8">  
  7. <title>Add User</title>  
  8.   
  9. <script type="text/javascript" src="${pageContext.request.contextPath}/resource/script/jquery-1.9.1.min.js"></script>  
  10. <script type="text/javascript">  
  11.     $(document).ready(function(){  
  12.         $("#button_submit").click(function(){  
  13.               
  14.             //序列化表单元素,返回json数据  
  15.             var params = $("#userForm").serializeArray();  
  16.               
  17.             //也可以把表单之外的元素按照name value的格式存进来  
  18.             //params.push({name:"hello",value:"man"});  
  19.               
  20.             $.ajax({  
  21.                 type:"POST",  
  22.                 url:"${pageContext.request.contextPath}/user/addUser5",  
  23.                 data:params,  
  24.                 success:function(data){  
  25.                     alert("成功");  
  26.                 },  
  27.                 error:function(e) {  
  28.                     alert("出错:"+e);  
  29.                 }  
  30.             });  
  31.         });  
  32.     });  
  33. </script>  
  34.   
  35. </head>  
  36. <body>  
  37.     <form id="userForm">  
  38.         <table>  
  39.             <tr>  
  40.                 <td>账号</td>  
  41.                 <td>  
  42.                     <input type="text" id="userName" name="userName">  
  43.                 </td>  
  44.             </tr>  
  45.             <tr>  
  46.                 <td>密码</td>  
  47.                 <td>  
  48.                     <input type="password" id="password" name="password">  
  49.                 </td>  
  50.             </tr>  
  51.             <tr>  
  52.                 <td> </td>  
  53.                 <td>  
  54.                     <input type="button" id="button_submit" value="提交">  
  55.                 </td>  
  56.             </tr>  
  57.         </table>  
  58.     </form>  
  59. </body>  
  60. </html>  

依然可以使用bean来接收json数据:

[java] view plaincopy
 
  1. @RequestMapping("/addUser5")  
  2.     public String addUser5(User user) {  
  3.         System.out.println("userName is:"+user.getUserName());  
  4.         System.out.println("password is:"+user.getPassword());  
  5.         return "/user/success";  
  6.     }  

 

分享到:
评论

相关推荐

    spring学习: spring mvc表单提交

    NULL 博文链接:https://shmilyaw-hotmail-com.iteye.com/blog/2244136

    SpringMVC之表单提交===③===多文件上传表单

    NULL 博文链接:https://dayongge.iteye.com/blog/2269217

    SpringMVC之表单提交===②===单文件上传表单

    NULL 博文链接:https://dayongge.iteye.com/blog/2268976

    spring mvc_05

    spring mvc 表单提交(非注解方式)

    [免费]Spring MVC学习指南(高清)

    全书共计12章,分别从Spring框架、模型2和MVC模式、Spring MVC介绍、控制器、数据绑定和表单标签库、传唤器和格式化、验证器、表达式语言、JSTL、国际化、上传文件、下载文件多个角度介绍了Spring MVC。除此之外,...

    精通Spring MVC 4

    Web 应用、精通 MVC 结构、处理表单和复杂的 URL 映射、文件上传与错误处理、创建 RESTful 应用、保护应用、单元测试与验收测试、优化请求、将 Web 应用部署到云等内容, 循序渐进地讲解了 Spring MVC 4 的开发技巧...

    大优惠 Spring MVC学习指南(第2版)2017.pdf

    全书共计12章,分别从Spring框架、模型2和MVC模式、Spring MVC介绍、控制器、数据绑定和表单标签库、传唤器和格式化、验证器、表达式语言、JSTL、国际化、上传文件、下载文件多个角度介绍了Spring MVC。除此之外,...

    layui 图片上传+表单提交+ Spring MVC的实例

    今天小编就为大家分享一篇layui 图片上传+表单提交+ Spring MVC的实例,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧

    使用Spring MVC表单标签_IT168文库.doc

    在低版本的Spring中,你必须通过JSTL或...不过这一情况已经一去不复返了,从Spring 2.0开始,Spring MVC开始全面支持表单标签,通过Spring MVC表单标签,我们可以很容易地将控制器相关的表单对象绑定到HTML表单元素中。

    Spring MVC学习指南

    全书共计12章,分别从Spring框架、模型2和MVC模式、Spring MVC介绍、控制器、数据绑定和表单标签库、传唤器和格式化、验证器、表达式语言、JSTL、国际化、上传文件、下载文件多个角度介绍了Spring MVC。除此之外,...

    Spring MVC.pptx

    详细的Spring MVC教程,内容包括控制器 重定向 保存并获取属性参数 拦截器 表单标签和验证表单 视图和视图解析器 上传文件 数据转换和格式化

    Spring MVC 向导控制器完整的例子

    这是一个简单完整的Spring MVC向导控制器(AbstractWizardFormController)的例子,包含所需的类包,可以运行,也是我重新熟悉Spring 的第二例子,明天再上传Spring 的例外个例子,如有问题,我们可以互相学习下.

    Spring MVC 3.0 单表单 同时提交 不同对象到后台

    自定义 RequestBean 注解 及 WebArgumentResolver 完成如下格式表单提交 最简单的 是 新定义 一个 过渡对象 Objects 其包含 user group.....等 然后用如上 格式提交 最终 到后台 进行各取所需

    Spring MVC表单标签库

    使用SprignMVC标签处理表单实例

    Spring.MVC-A.Tutorial-Spring.MVC学习指南

    全书共计12章,分别从Spring框架、模型2和MVC模式、Spring MVC介绍、控制器、数据绑定和表单标签库、传唤器和格式化、验证器、表达式语言、JSTL、国际化、上传文件、下载文件多个角度介绍了Spring MVC。除此之外,...

    spring mvc服务端表单验证实例

    spring mvc服务端表单验证实例 能跑起来看效果 lib齐全 希望对您的学习有帮助

    spring MVC 简单登陆例子

    一个简单的基于Spring MVC的简单登陆的例子,在这个例子中,把表单提交的用户名和密码封装到实体类中传递到controller中,项目代码使用注解模式。表单中的用户名和密码完全相同才能登陆成功。

    spring mvc标签使用指南

    13.9. 使用Spring的表单标签库 1 13.9.1. 配置 1 13.9.2. form标签 1 13.9.3. input标签 3 13.9.4. checkbox标签 3 13.9.5. checkboxes标签 6 13.9.6. radiobutton标签 6 13.9.7. radiobuttons标签 7 13.9.8. ...

    spring mvc深入总结

    spring mvc 深入总结,文章是转载拷贝而来,谢谢原作者!

Global site tag (gtag.js) - Google Analytics