一个普通的表单。

  表单的代码如下:

  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. <script type="text/javascript">
  9. //添加用户
  10. function addUser() {
  11. var form = document.forms[0];
  12. form.action = "${pageContext.request.contextPath}/user/addUser1";
  13. //form.action = "${pageContext.request.contextPath}/user/addUser2";
  14. //form.action = "${pageContext.request.contextPath}/user/addUser3";
  15. form.method = "post";
  16. form.submit();
  17. }
  18. </script>
  19. </head>
  20. <body>
  21. <form>
  22. <table>
  23. <tr>
  24. <td>账号</td>
  25. <td>
  26. <input type="text" name="userName">
  27. </td>
  28. </tr>
  29. <tr>
  30. <td>密码</td>
  31. <td>
  32. <input type="password" name="password">
  33. </td>
  34. </tr>
  35. <tr>
  36. <td> </td>
  37. <td>
  38. <input type="button" value="提交" onclick="addUser()">
  39. </td>
  40. </tr>
  41. </table>
  42. </form>
  43. </body>
  44. </html>

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

  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接收

  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

  1. public class User {
  2. private String userName;
  3. private String password;
  4. public String getUserName() {
  5. return userName;
  6. }
  7. public void setUserName(String userName) {
  8. this.userName = userName;
  9. }
  10. public String getPassword() {
  11. return password;
  12. }
  13. public void setPassword(String password) {
  14. this.password = password;
  15. }
  16. }

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

  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数据接收

  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. <script type="text/javascript" src="${pageContext.request.contextPath}/resource/script/jquery-1.9.1.min.js"></script>
  9. <script type="text/javascript">
  10. $(document).ready(function(){
  11. $("#button_submit").click(function(){
  12. var name = $("#userName").val();
  13. var pass = $("#password").val();
  14. var user = {userName:name,password:pass};//拼装成json格式
  15. $.ajax({
  16. type:"POST",
  17. url:"${pageContext.request.contextPath}/user/addUser4",
  18. data:user,
  19. success:function(data){
  20. alert("成功");
  21. },
  22. error:function(e) {
  23. alert("出错:"+e);
  24. }
  25. });
  26. });
  27. });
  28. </script>
  29. </head>
  30. <body>
  31. <form>
  32. <table>
  33. <tr>
  34. <td>账号</td>
  35. <td>
  36. <input type="text" id="userName" name="userName">
  37. </td>
  38. </tr>
  39. <tr>
  40. <td>密码</td>
  41. <td>
  42. <input type="password" id="password" name="password">
  43. </td>
  44. </tr>
  45. <tr>
  46. <td> </td>
  47. <td>
  48. <input type="button" id="button_submit" value="提交">
  49. </td>
  50. </tr>
  51. </table>
  52. </form>
  53. </body>
  54. </html>

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

  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数据结构数据。

  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. <script type="text/javascript" src="${pageContext.request.contextPath}/resource/script/jquery-1.9.1.min.js"></script>
  9. <script type="text/javascript">
  10. $(document).ready(function(){
  11. $("#button_submit").click(function(){
  12. //序列化表单元素,返回json数据
  13. var params = $("#userForm").serializeArray();
  14. //也可以把表单之外的元素按照name value的格式存进来
  15. //params.push({name:"hello",value:"man"});
  16. $.ajax({
  17. type:"POST",
  18. url:"${pageContext.request.contextPath}/user/addUser5",
  19. data:params,
  20. success:function(data){
  21. alert("成功");
  22. },
  23. error:function(e) {
  24. alert("出错:"+e);
  25. }
  26. });
  27. });
  28. });
  29. </script>
  30. </head>
  31. <body>
  32. <form id="userForm">
  33. <table>
  34. <tr>
  35. <td>账号</td>
  36. <td>
  37. <input type="text" id="userName" name="userName">
  38. </td>
  39. </tr>
  40. <tr>
  41. <td>密码</td>
  42. <td>
  43. <input type="password" id="password" name="password">
  44. </td>
  45. </tr>
  46. <tr>
  47. <td> </td>
  48. <td>
  49. <input type="button" id="button_submit" value="提交">
  50. </td>
  51. </tr>
  52. </table>
  53. </form>
  54. </body>
  55. </html>

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

    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. }

SpringMVC接收页面表单参数的更多相关文章

  1. SpringMVC接收页面表单参数-java-电脑编程网

    body { font-family: "Microsoft YaHei UI","Microsoft YaHei",SimSun,"Segoe UI ...

  2. SpringMVC接收页面表单参数(转)

    作者:CN.programmer.Luxh 和java相关 一个普通的表单. 表单的代码如下: <%@ page language="java" contentType=&q ...

  3. SpringMVC获取页面表单参数的几种方式

      以下几种方式只有在已搭好的SpringMVC环境中,才能执行成功!      首先,写一个登陆页面和一个Bean类 <%@ page language="java" co ...

  4. spring mvc 接收页面表单List

    很少写博客,如果写的不好请多多包涵! 最近在用Spring mvc时遇到一个问题,在网上搜了很多资料.几乎没看到解决办法! 例如:当我们在做批量添加或者更新时,在Controller层接收表单数据的问 ...

  5. 把JSON数据载入到页面表单的两种思路(对easyui自带方法进行改进)

    #把JSON数据载入到页面表单的两种思路(对easyui自带方法进行改进) ##背景 项目中经常需要把JSON数据填充到页面表单,一开始我使用easyui自带的form load方法,觉得效率很低,经 ...

  6. html 页面表单如果是disabled,则不能提交到服务器端,request.getParameter得到的将为null

    html 页面表单如果是disabled,则不能提交到服务器端,request.getParameter得到的将为null 解决方法:使用hidden 利用javascript赋值,传递到后台

  7. 记录ASP.NET页面表单初始状态(主要是为了前台可以根据这个判断页面是否变动了)

    把页面表单状态记录到HiddenField中. 这里只提供后台代码, 前台逻辑根据需求自由定义. 存放值的ViewState: protected Dictionary<string, stri ...

  8. 使用JQuery.Validate插件来校验页面表单有效性

    使用JQuery.Validate插件来校验页面表单有效性​1. [代码] 常见的注册表单元素 <form action="#" method="post" ...

  9. JavaScript学习——使用JS完成注册页面表单校验

    1.步骤分析 第一步:确定事件(onsubmit)并为其绑定一个函数 第二步:书写这个函数(获取用户输入的数据<获取数据时需要在指定位置定义一个 id>) 第三步:对用户输入的数据进行判断 ...

随机推荐

  1. delphi.位操作

    位操作网上有很多介绍,请上网google/baidu,比如: 位操作技巧实例大全: http://blog.csdn.net/g_spider/article/details/5750665 位操作基 ...

  2. 北京易信软科信息技术有限公司-仓库管理系统V1.0

    北京易信软科您可信赖的北京软件研发服务商,公司团队有多年应用软件设计制作及开发经验,为各大企业提供软件设计.制作及维护服务,为用户提供可靠高效的应用服务平台 我们通过专业的项目实施流程,为您提供优质的 ...

  3. LR12.53—第1课:构建Vuser脚本

    第1课:构建Vuser脚本 要生成系统上的负载,首先建立一个可以运行以模拟真实用户行为Vuser脚本.您使用VuGen创建和构建Vuser脚本. 在这一课中,你将涵盖以下主题: 介绍VuGen将 - ...

  4. 再谈vertical-align与line-height

    每次遇到多个inline-block元素排列的怪异垂直位置的问题的时候都可以通过经验,设置vertical-align来解决,没深入研究过,现在需要分析总结下这个问题. 问题引出 有小鲜肉新做了个页面 ...

  5. 前端学习实践笔记--JavaScript深入【3】

    这章主要讨论闭包和原型,以及面向对象和继承. 闭包 闭包充分利用了JS里面作用域的概念,作用域的好处是内部函数可以访问定义它们的外部函数的参数和变量.使用闭包主要是为了读取函数内部的变量或者将函数内部 ...

  6. BroadCast小结

    1.BroadCast注册方式 静态注册:即在AndroidManifest.xml 文件中定义 <receiver android:name=".BroadCastB"&g ...

  7. 【原创】android内存管理-hprof文件

    转载请注明出处 http://www.cnblogs.com/weiwangnuanyang/p/5703702.html 如果只是想确定一下某一个场景是否有内存泄漏,AndroidStadio的控制 ...

  8. js prepend() 和append()区别

    prepend() 方法在被选元素的开头(仍位于内部)插入指定内容.prepend() 语法:$(selector).prepend(content) 或 $(selector).prepend(fu ...

  9. [转载]SVN-主干/分支

    一个大项目在开发中可能会拆分成几个小项目,分别分去,同时共通的部分再由人做,做完后再统一合并.同时,在开发中,共通的部分修改后,其它人要保持同步. 这种情况反应到SVN的分支/合并功能上,再贴切不过了 ...

  10. BIO,NIO,AIO

    同步阻塞IO(JAVA BIO):     同步并阻塞,服务器实现模式为一个连接一个线程,即客户端有连接请求时服务器端就需要启动一个线程进行处理,如果这个连接不做任何事情会造成不必要的线程开销,当然可 ...