美文网首页
第五章 Servlet 表单数据

第五章 Servlet 表单数据

作者: LeeSpringFly | 来源:发表于2019-07-26 10:12 被阅读0次

    关于本篇文章

    了解一些 servlet 概念,本编文章只进行一些文章格式修改,文章内使用的图片均来自 Runoob 网站

    致谢

    感谢 Runoob 提供的相关资料,官方资料地址Servlet 教程

    GET 方法

    GET 方法想服务器发送页面请求包含已编码的用户信息。页面和已编码的信息中间用? 字符分隔,如下:

    http://www.test.com/hello?key1=value1&key2=value2
    

    GET 方法是默认的从浏览器向 Web 服务器传递信息的方式,他会产生一个很长的字符串,出现在地址栏中。GET 方法有大小限制:最多只能有1024个字符。这些信息使用 QUERY_STRING 头传递,并可以通过 QUERY_STRING 环境变量访问,Servlet 使用 doGet() 方法处理这种类型的请求。

    POST 方法

    POST 方法打包信息与 GET 方式基本相同,但 POST 不把信息放在 URL 中,而是作为单独的信息传递给后台。Servlet 使用 doPost() 方法处理这种类型的请求。

    使用 Servlet 读取表单数据

    • getParameter() : request.getParameter() 用于获取表单参数的值
    • getParameterValues() : 如果参数出现一次以上,则调用该方法,返回多个值。例如复选框
    • getParameterNames() : 获取请求表单中的所有参数

    使用 URL 的 GET 方法实例

    获取下面 URL 中的两个值

    http://localhost:8080/TomcatTest/HelloForm?name=菜鸟教程&url=www.runoob.com

    package com.runoob.test;
    
    import java.io.IOException;
    import java.io.PrintWriter;
    
    import javax.servlet.ServletException;
    import javax.servlet.annotation.WebServlet;
    import javax.servlet.http.HttpServlet;
    import javax.servlet.http.HttpServletRequest;
    import javax.servlet.http.HttpServletResponse;
    
    /**
     * Servlet implementation class HelloForm
     */
    @WebServlet("/HelloForm")
    public class HelloForm extends HttpServlet {
        private static final long serialVersionUID = 1L;
           
        /**
         * @see HttpServlet#HttpServlet()
         */
        public HelloForm() {
            super();
            // TODO Auto-generated constructor stub
        }
    
        /**
         * @see HttpServlet#doGet(HttpServletRequest request, HttpServletResponse response)
         */
        protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
            // 设置响应内容类型
            response.setContentType("text/html;charset=UTF-8");
    
            PrintWriter out = response.getWriter();
            String title = "使用 GET 方法读取表单数据";
            // 处理中文
            String name =new String(request.getParameter("name").getBytes("ISO8859-1"),"UTF-8");
            String docType = "<!DOCTYPE html> \n";
            out.println(docType +
                "<html>\n" +
                "<head><title>" + title + "</title></head>\n" +
                "<body bgcolor=\"#f0f0f0\">\n" +
                "<h1 align=\"center\">" + title + "</h1>\n" +
                "<ul>\n" +
                "  <li><b>站点名</b>:"
                + name + "\n" +
                "  <li><b>网址</b>:"
                + request.getParameter("url") + "\n" +
                "</ul>\n" +
                "</body></html>");
        }
        
        // 处理 POST 方法请求的方法
        public void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
            doGet(request, response);
        }
    }
    

    然后我们在 web.xml 中创建一下条目

    <?xml version="1.0" encoding="UTF-8"?>
    <web-app>
      <servlet>
        <servlet-name>HelloForm</servlet-name>
        <servlet-class>com.runoob.test.HelloForm</servlet-class>
      </servlet>
      <servlet-mapping>
        <servlet-name>HelloForm</servlet-name>
        <url-pattern>/TomcatTest/HelloForm</url-pattern>
      </servlet-mapping>
    </web-app>
    

    现在启动 Tomcat,在浏览器地址中输入 http://localhost:8080/TomcatTest/HelloForm?name=菜鸟教程&url=www.runoob.com,如果一些顺利,页面将返回 URL 中的数据,菜鸟教程和www.runoob.com

    使用表单的 GET 方法实例

    下面是一个简单的实例,使用 HTML 表单和提交按钮传递两个值。我们将使用相同的 Servlet HelloForm 来处理输入。

    <!DOCTYPE html>
    <html>
    <head>
        <meta charset="utf-8">
        <title>菜鸟教程(runoob.com)</title>
    </head>
    <body>
        <form action="HelloForm" method="GET">
            网址名:<input type="text" name="name">
            <br />
            网址:<input type="text" name="url" />
            <input type="submit" value="提交" />
        </form>
    </body>
    </html>
    

    提交表单后,页面会返回输入的数据。

    使用表单的 POST 方法实例

    现在将页面中的 GET 提交方法,改成 POST

    <form action="HelloForm" method="GET">

    改成 <form action="HelloForm" method="POST">

    Java 代码

    package com.runoob.test;
    
    import java.io.IOException;
    import java.io.PrintWriter;
    
    import javax.servlet.ServletException;
    import javax.servlet.annotation.WebServlet;
    import javax.servlet.http.HttpServlet;
    import javax.servlet.http.HttpServletRequest;
    import javax.servlet.http.HttpServletResponse;
    
    /**
     * Servlet implementation class HelloForm
     */
    @WebServlet("/HelloForm")
    public class HelloForm extends HttpServlet {
        private static final long serialVersionUID = 1L;
           
        /**
         * @see HttpServlet#HttpServlet()
         */
        public HelloForm() {
            super();
            // TODO Auto-generated constructor stub
        }
    
        /**
         * @see HttpServlet#doGet(HttpServletRequest request, HttpServletResponse response)
         */
        protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
            // 设置响应内容类型
            response.setContentType("text/html;charset=UTF-8");
    
            PrintWriter out = response.getWriter();
            String title = "使用 POST 方法读取表单数据";
            // 处理中文
            String name =new String(request.getParameter("name").getBytes("ISO8859-1"),"UTF-8");
            String docType = "<!DOCTYPE html> \n";
            out.println(docType +
                "<html>\n" +
                "<head><title>" + title + "</title></head>\n" +
                "<body bgcolor=\"#f0f0f0\">\n" +
                "<h1 align=\"center\">" + title + "</h1>\n" +
                "<ul>\n" +
                "  <li><b>站点名</b>:"
                + name + "\n" +
                "  <li><b>网址</b>:"
                + request.getParameter("url") + "\n" +
                "</ul>\n" +
                "</body></html>");
        }
        
        // 处理 POST 方法请求的方法
        public void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
            doGet(request, response);
        }
    }
    

    提交表单后,页面会返回输入的数据。

    POST 提交

    将复选框数据传递到 Servlet 程序

    当需要选择一个以上的选项时,则使用复选框。

    下面是一个 HTML 代码实例 checkbox.html,一个带有两个复选框的表单。

    <!DOCTYPE html>
    <html>
    <head>
      <meta charset="utf-8">
      <title>菜鸟教程(runoob.com)</title>
    </head>
    <body>
      <form action="CheckBox" method="POST" target="_blank">
        <input type="checkbox" name="runoob" checked="checked" /> 菜鸟教程
        <input type="checkbox" name="google"  /> Google
        <input type="checkbox" name="taobao" checked="checked" /> 淘宝
        <input type="submit" value="选择站点" />
    </form>
    </body>
    </html>
    

    下面是 CheckBox.java Servlet 程序,处理 Web 浏览器给出的复选框输入。

    package com.runoob.test;
    
    import java.io.IOException;
    import java.io.PrintWriter;
    
    import javax.servlet.ServletException;
    import javax.servlet.annotation.WebServlet;
    import javax.servlet.http.HttpServlet;
    import javax.servlet.http.HttpServletRequest;
    import javax.servlet.http.HttpServletResponse;
    
    /**
     * Servlet implementation class CheckBox
     */
    @WebServlet("/CheckBox")
    public class CheckBox extends HttpServlet {
        private static final long serialVersionUID = 1L;
        
        protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
            
            // 设置响应内容类型
            response.setContentType("text/html;charset=UTF-8");
    
            PrintWriter out = response.getWriter();
            String title = "读取复选框数据";
            String docType = "<!DOCTYPE html> \n";
                out.println(docType +
                    "<html>\n" +
                    "<head><title>" + title + "</title></head>\n" +
                    "<body bgcolor=\"#f0f0f0\">\n" +
                    "<h1 align=\"center\">" + title + "</h1>\n" +
                    "<ul>\n" +
                    "  <li><b>菜鸟按教程标识:</b>: "
                    + request.getParameter("runoob") + "\n" +
                    "  <li><b>Google 标识:</b>: "
                    + request.getParameter("google") + "\n" +
                    "  <li><b>淘宝标识:</b>: "
                    + request.getParameter("taobao") + "\n" +
                    "</ul>\n" +
                    "</body></html>");
        }
        
        // 处理 POST 方法请求的方法
        public void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
            doGet(request, response);
        }
    }
    

    设置对应的 web.xml:

    <?xml version="1.0" encoding="UTF-8"?>
    <web-app>
      <servlet>
        <servlet-name>CheckBox</servlet-name>
        <servlet-class>com.runoob.test.CheckBox</servlet-class>
      </servlet>
      <servlet-mapping>
        <servlet-name>CheckBox</servlet-name>
        <url-pattern>/TomcatTest/CheckBox</url-pattern>
      </servlet-mapping>
    </web-app>
    

    上面的实例将显示下面的结果:

    复选框数据

    读取所有的表单参数

    以下是通用的实例,使用 HttpServletRequest 的 getParameterNames() 方法读取所有可用的表单参数。该方法返回一个枚举,其中包含未指定顺序的参数名。

    一旦我们有一个枚举,我们可以以标准方式循环枚举,使用 hasMoreElements() 方法来确定何时停止,使用 nextElement() 方法来获取每个参数的名称。

    import java.io.IOException;
    import java.io.PrintWriter;
    import java.util.Enumeration;
    
    import javax.servlet.ServletException;
    import javax.servlet.annotation.WebServlet;
    import javax.servlet.http.HttpServlet;
    import javax.servlet.http.HttpServletRequest;
    import javax.servlet.http.HttpServletResponse;
    
    /**
     * Servlet implementation class ReadParams
     */
    @WebServlet("/ReadParams")
    public class ReadParams extends HttpServlet {
        private static final long serialVersionUID = 1L;
           
        /**
         * @see HttpServlet#HttpServlet()
         */
        public ReadParams() {
            super();
            // TODO Auto-generated constructor stub
        }
    
        /**
         * @see HttpServlet#doGet(HttpServletRequest request, HttpServletResponse response)
         */
        protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
            // 设置响应内容类型
            response.setContentType("text/html;charset=UTF-8");
            PrintWriter out = response.getWriter();
            String title = "读取所有的表单数据";
            String docType =
                "<!doctype html public \"-//w3c//dtd html 4.0 " +
                "transitional//en\">\n";
                out.println(docType +
                "<html>\n" +
                "<head><meta charset=\"utf-8\"><title>" + title + "</title></head>\n" +
                "<body bgcolor=\"#f0f0f0\">\n" +
                "<h1 align=\"center\">" + title + "</h1>\n" +
                "<table width=\"100%\" border=\"1\" align=\"center\">\n" +
                "<tr bgcolor=\"#949494\">\n" +
                "<th>参数名称</th><th>参数值</th>\n"+
                "</tr>\n");
    
            Enumeration paramNames = request.getParameterNames();
    
            while(paramNames.hasMoreElements()) {
                String paramName = (String)paramNames.nextElement();
                out.print("<tr><td>" + paramName + "</td>\n");
                String[] paramValues =
                request.getParameterValues(paramName);
                // 读取单个值的数据
                if (paramValues.length == 1) {
                    String paramValue = paramValues[0];
                    if (paramValue.length() == 0)
                        out.println("<td><i>没有值</i></td>");
                    else
                        out.println("<td>" + paramValue + "</td>");
                } else {
                    // 读取多个值的数据
                    out.println("<td><ul>");
                    for(int i=0; i < paramValues.length; i++) {
                    out.println("<li>" + paramValues[I]);
                }
                    out.println("</ul></td>");
                }
                out.print("</tr>");
            }
            out.println("\n</table>\n</body></html>");
        }
    
        /**
         * @see HttpServlet#doPost(HttpServletRequest request, HttpServletResponse response)
         */
        protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
            // TODO Auto-generated method stub
            doGet(request, response);
        }
    
    }
    

    现在,通过下面的表单尝试上面的 Servlet:

    <!DOCTYPE html>
    <html>
    <head>
        <meta charset="utf-8">
        <title>菜鸟教程(runoob.com)</title>
    </head>
    <body>
    
        <form action="ReadParams" method="POST" target="_blank">
            <input type="checkbox" name="maths" checked="checked" /> 数学
            <input type="checkbox" name="physics"  /> 物理
            <input type="checkbox" name="chemistry" checked="checked" /> 化学
            <input type="submit" value="选择学科" />
        </form>
    
    </body>
    </html>
    

    设置相应的 web.xml:

    <?xml version="1.0" encoding="UTF-8"?>
    <web-app>
      <servlet>
        <servlet-name>ReadParams</servlet-name>
        <servlet-class>com.runoob.test.ReadParams</servlet-class>
      </servlet>
      <servlet-mapping>
        <servlet-name>ReadParams</servlet-name>
        <url-pattern>/TomcatTest/ReadParams</url-pattern>
      </servlet-mapping>
    </web-app>
    

    现在使用上面的表单调用 Servlet,将产生以下结果:

    所有的表单参数

    您可以尝试使用上面的 Servlet 来读取其他的表单数据,比如文本框、单选按钮或下拉框等。

    相关文章

      网友评论

          本文标题:第五章 Servlet 表单数据

          本文链接:https://www.haomeiwen.com/subject/lmfrrctx.html