SpringMVC接收页面表单参数

一个普通的表单。

  表单的代码如下:

[java] view plain copy

  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相应的方法的形参中

[java] view plain copy

  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 plain copy

  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 plain copy

  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来封装接收的参数

[java] view plain copy

  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 plain copy

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

[java] view plain copy

  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 plain copy

  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数据:

[java] view plain copy

    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. }
时间: 2024-07-30 10:11:26

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

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

body { font-family: "Microsoft YaHei UI","Microsoft YaHei",SimSun,"Segoe UI",Tahoma,Helvetica,Sans-Serif,"Microsoft YaHei", Georgia,Helvetica,Arial,sans-serif,宋体, PMingLiU,serif; font-size: 10.5pt; line-height: 1.5;

asp页面表单提交在后台不能获取问题

今天碰到一个奇葩的问题,asp页面表单提交后,有一个文本框<input type="text" name="phone" id="phone" />在后台获取不了, 这个标签在form表单内,也有name属性,但是在后台就是获取不了这个标签的值,而其他的文本框.复选框都可以获取到,这可就奇怪了! 几经周折,终于找到了原因,原来我在提交表单的时候,name = "phone"这个标签此时在一个javascript事件

JavaScript学习——完成注册页面表单校验

1.步骤分析 第一步:确定事件(onsubmit)并为其绑定一个函数 第二步:书写这个函数(获取用户输入的数据<获取数据时需要在指定位置定义一个 id>) 第三步:对用户输入的数据进行判断 第四步:数据合法(让表单提交) 第五步:数据非法(给出错误提示信息,不让表单提交) 问题:如何控制表单提交? 关于事件 onsubmit:一般用于表单提交的位置,那么需要在定义函数的时候给出一个 返回值. onsubmit = return checkForm() 2.完成注册页面表单校验(基于HTML&a

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

使用JQuery.Validate插件来校验页面表单有效性?1. [代码] 常见的注册表单元素 <form action="#" method="post"  id="regist">     <table cellpadding="0" cellspacing="0" border="0" class="form_table">      

Spring MVC无法获取到页面表单put过来的参数的解决方案

问题: 在使用Spring MVC开发resetful风格的Web应用时,发现Sping接收不到页面Form表单传到后台的值. 解决: 1.把Spring及Spring MVC的版本升级到3.1.1 <org.springframework.version>3.1.1.RELEASE</org.springframework.version> 2.增加HttpPutFormContentFilter过滤器 <filter> <filter-name>Http

JavaScript学习——完善注册页面表单校验

1.之前我们已经使用弹出框的方式实现了表单校验的功能,但是此种方式用户体验效果很差 我们希望做成把提示信息和校验结果放在输入栏的后面. 2.步骤分析 (此案例基于HTML&CSS--网站注册页面实现的) 第一步:确定事件(onfocus 聚焦事件)并为其绑定一个函数 第二步:书写绑定函数(在输入框的后面给出提示信息) 第三步:确定事件(onblur 离焦事件)并为其绑定一个函数 第四步:书写函数(对数据进行校验,分别给出提示) JS代码:(传入参数的目的减少重复代码,增加通用性) 1 <sc

使用dreamweaver设计常用注册页面表单验证

网页注册页面验证设计,必须使用dreamweaver的表单来实现,或者spry库. 这里介绍的第一个是最原始的表单验证方式,即没有使用即时验证,需要点击提交按钮才进行验证,也没有使用正则表达式或者AJAX验证,也或者是JQuery的验证,不过这么多验证方式接着第一个后面都会写出来的 1.最原始的注册验证方式,需要通过点击提交按钮才验证 先上图 代码如下: Html代码 复制代码 收藏代码 1. 2. 3. 4. 5.无标题文档 6. 8. 9. 11. 219. 注册步骤: 1.填写信息 > 2

HTML 之 Web页面表单form中只有一个input的text元素,按回车默认提交

WEB开发中,如果页面的 form 中只有一个input元素,在该input元素的输入框中按回车(注:此时并没有写对应的onkeydown等事件处理),则浏览器会默认提交表单,请看如下代码: <html> <head> <title>页面中只有一个input元素时默认提交表单</title> </head> <body> <form action="http://www.baidu.com" name=&qu

jsp页面表单的遍历要怎么写

1.传统的方式使用request.getAttribute(“list”);获取表单的值, 2.也可以用struts2提供的标签进行遍历 备注 // 传统的接受参数方法 // String sfz=this.getRequest().getParameter("sfz"); // String ddz=this.getRequest().getParameter("ddz"); // 传统的返回参数方法 // this.getRequest().setAttribu