zoukankan      html  css  js  c++  java
  • SpringMVC接收页面表单参数

      一个普通的表单。

      表单的代码如下:

    <%@ page language="java" contentType="text/html; charset=UTF-8"
        pageEncoding="UTF-8"%>
    <!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
    <html>
    <head>
    <meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
    <title>Add User</title>
    
    
    <script type="text/javascript">
        //添加用户
        function addUser() {
            var form = document.forms[0];
            form.action = "${pageContext.request.contextPath}/user/addUser1";
            //form.action = "${pageContext.request.contextPath}/user/addUser2";
            //form.action = "${pageContext.request.contextPath}/user/addUser3";
            form.method = "post";
            form.submit();
        }
    </script>
    
    </head>
    <body>
        <form>
            <table>
                <tr>
                    <td>账号</td>
                    <td>
                        <input type="text" name="userName">
                    </td>
                </tr>
                <tr>
                    <td>密码</td>
                    <td>
                        <input type="password" name="password">
                    </td>
                </tr>
                <tr>
                    <td>&nbsp;</td>
                    <td>
                        <input type="button" value="提交" onclick="addUser()">
                    </td>
                </tr>
            </table>
        </form>
    </body>
    </html>

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

    @RequestMapping("/addUser1")
        public String addUser1(String userName,String password) {
            System.out.println("userName is:"+userName);
            System.out.println("password is:"+password);
            return "/user/success";
        }

      2、通过HttpServletRequest接收

    @RequestMapping("/addUser2")
        public String addUser2(HttpServletRequest request) {
            String userName = request.getParameter("userName");
            String password = request.getParameter("password");
            System.out.println("userName is:"+userName);
            System.out.println("password is:"+password);
            return "/user/success";
        }

      3、通过一个bean来接收

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

    public class User {
        
        private String userName;
        
        private String password;
    
        public String getUserName() {
            return userName;
        }
    
        public void setUserName(String userName) {
            this.userName = userName;
        }
    
        public String getPassword() {
            return password;
        }
    
        public void setPassword(String password) {
            this.password = password;
        }
    }

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

    @RequestMapping("/addUser3")
        public String addUser3(User user) {
            System.out.println("userName is:"+user.getUserName());
            System.out.println("password is:"+user.getPassword());
            return "/user/success";
        }

       4、通过json数据接收

    <%@ page language="java" contentType="text/html; charset=UTF-8"
        pageEncoding="UTF-8"%>
    <!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
    <html>
    <head>
    <meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
    <title>Add User</title>
    
    <script type="text/javascript" src="${pageContext.request.contextPath}/resource/script/jquery-1.9.1.min.js"></script>
    <script type="text/javascript">
        $(document).ready(function(){
            $("#button_submit").click(function(){
                var name = $("#userName").val();
                var pass = $("#password").val();
                
    var user = {userName:name,password:pass};//拼装成json格式 $.ajax({ type:"POST", url:"${pageContext.request.contextPath}/user/addUser4", data:user, success:function(data){ alert("成功"); }, error:function(e) { alert("出错:"+e); } }); }); }); </script> </head> <body> <form> <table> <tr> <td>账号</td> <td> <input type="text" id="userName" name="userName"> </td> </tr> <tr> <td>密码</td> <td> <input type="password" id="password" name="password"> </td> </tr> <tr> <td>&nbsp;</td> <td> <input type="button" id="button_submit" value="提交"> </td> </tr> </table> </form> </body> </html>

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

    @RequestMapping("/addUser4")
        public String addUser4(User user) {
            System.out.println("userName is:"+user.getUserName());
            System.out.println("password is:"+user.getPassword());
            return "/user/success";
        }

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

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

    <%@ page language="java" contentType="text/html; charset=UTF-8"
        pageEncoding="UTF-8"%>
    <!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
    <html>
    <head>
    <meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
    <title>Add User</title>
    
    <script type="text/javascript" src="${pageContext.request.contextPath}/resource/script/jquery-1.9.1.min.js"></script>
    <script type="text/javascript">
        $(document).ready(function(){
            $("#button_submit").click(function(){
                
                //序列化表单元素,返回json数据
                var params = $("#userForm").serializeArray();
                
                //也可以把表单之外的元素按照name value的格式存进来
                //params.push({name:"hello",value:"man"});
                
                $.ajax({
                    type:"POST",
                    url:"${pageContext.request.contextPath}/user/addUser5",
                    data:params,
                    success:function(data){
                        alert("成功");
                    },
                    error:function(e) {
                        alert("出错:"+e);
                    }
                });
            });
        });
    </script>
    
    </head>
    <body>
        <form id="userForm">
            <table>
                <tr>
                    <td>账号</td>
                    <td>
                        <input type="text" id="userName" name="userName">
                    </td>
                </tr>
                <tr>
                    <td>密码</td>
                    <td>
                        <input type="password" id="password" name="password">
                    </td>
                </tr>
                <tr>
                    <td>&nbsp;</td>
                    <td>
                        <input type="button" id="button_submit" value="提交">
                    </td>
                </tr>
            </table>
        </form>
    </body>
    </html>

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

    @RequestMapping("/addUser5")
        public String addUser5(User user) {
            System.out.println("userName is:"+user.getUserName());
            System.out.println("password is:"+user.getPassword());
            return "/user/success";
        }
  • 相关阅读:
    git config配置,工作区和版本库联系。
    自动化监控系统(四) 客户端设计
    17、如何对字符串进行左, 右, 居中对齐 18、如何去掉字符串中不需要的字符 19、如何读写文本文件 20、如何处理二进制文件 21、如何设置文件的缓冲
    13、如何拆分含有多种分隔符的字符串 14、如何判断字符串a是否以字符串b开头或结尾 15、如何调整字符串中文本的格式 16、如何将多个小字符串拼接成一个大的字符串
    8、如何实现可迭代对象和迭代器对象 9、如何使用生成器函数实现可迭代对象 10、如何进行反向迭代以及如何实现反向迭代 11、如何对迭代器做切片操作 12、如何在一个for语句中迭代多个可迭代对象
    5、如何快速找到多个字典中的公共键(key) 6 如何让字典保持有序 7 如何实现用户的历史记录功能(最多n条)
    1、如何在列表,字典,集合种根据条件筛选数据?2、如何为元组中的每个元素命名,提高程序的可读性3、如何统计出序列中元素出现的频度4、如何根据字典中value的大小,对字典的key进行排序
    自动化监控系统(三) 搭建xadmin做网站后台
    自动化监控系统(二)连接数据库,创建app,添加model,同步数据库
    自动化监控系统(一)需求分析、架构设计
  • 原文地址:https://www.cnblogs.com/luxh/p/2960152.html
Copyright © 2011-2022 走看看