很多情况下,需要传递一些信息,从浏览器到Web服务器,最终到后台程序。浏览器使用两种方法可将这些信息传递到Web服务器,分别为GET方法和POST方法。

1.GET方法

GET 方法向页面请求发送已编码的用户信息。页面和已编码的信息中间用“?”字符分隔,如下所示:

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

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

2.POST方法

另一个向后台程序传递信息的比较可靠的方法是POST方法。POST方法打包信息的方式与GET方法基本相同,但是POST方法不是把信息作为URL中?字符后的文本字符串进行发送,而是把这些信息作为一个单独的消息。消息以标准输出的形式传到后台程序,您可以解析和使用这些标准输出。Servlet使用doPost()方法处理这种类型的请求。

使用Servlet读取表单数据,需要根据数据的不同使用不同的方法进行解析,在Servlet API中,定义了如下方法来解析不同类型的数据:

●  getParameter():可以调用request.getParameter()方法来获取表单参数的值。返回值类型为String。

●  getParameterValues():如果参数出现一次以上,则调用该方法,并返回多个值,例如复选框。返回值类型为String数组。

●  getParameterNames():如果想要得到当前请求中的所有参数的完整列表,则调用该方法。返回值类型为String数组。

下面的案例使用Servlet API获取GET请求中的参数:

package com.xdl.form;

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;

public class HelloForm extends HttpServlet {

private static final long serialVersionUID = 1L;

public HelloForm() {

super();

}

protected void doGet(HttpServletRequest request,

HttpServletResponse response) throws ServletException, IOException {

response.setContentType("text/html;charset=UTF-8");

PrintWriter out = response.getWriter();

String title = "使用 GET 方法读取表单数据";

//在Tomcat7版本中需要使用下面的方式处理GET方式传递中文乱码问题

//String name =new String

//(request.getParameter("name").getBytes ("ISO-8859-1"),"UTF-8");

//在Tomcat8版本中不需要处理GET方式传递中文乱码问题,

//因为Tomcat8默认使用UTF-8作为字符集传递中文参数,

//而Tomcat7默认使用的是ISO-8859-1字符集

String name = request.getParameter("name");

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>");

}

public void doPost(HttpServletRequest request,

HttpServletResponse response) throws ServletException, IOException {

doGet(request, response);

}

}

然后在web.xml文件中配置上面的Servlet:

<servlet>

<servlet-name>HelloForm</servlet-name>

<servlet-class>com.xdl.form.HelloForm</servlet-class>

</servlet>

<servlet-mapping>

<servlet-name>HelloForm</servlet-name>

<url-pattern>/HelloForm</url-pattern>

</servlet-mapping>

现在在浏览器的地址栏中输入http://localhost:8080/form-test/HelloForm?name=兄弟连java&url=java.itxdl.cn,并在触发上述命令之前确保已经启动Tomcat服务器,如果一切顺利,会得到如图2.1所示的结果:

HelloForm生成的HTML页面

下面使用HTML表单和提交按钮传递两个值,继续使用HelloForm来处理输入。

<!DOCTYPE html>

<html>

<head>

<meta charset="utf-8">

<title>兄弟连it教育(java.itxdl.cn)</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>

将这个HTML文件保存在WebContent下并命名为hello.html,然后重启Tomcat服务器,在浏览器中输入http://localhost:8080/ form-test /hello.html,浏览器中将显示如图所示的内容。

hello.html

在网址名中输入:变态严管 网址栏中输入:java.itxdl.cn 然后点击提交按钮,将看到如图所示的页面。

HelloForm生成的HTML页面

让我们对上面的HelloForm做小小的修改,以便它可以处理GET和POST方法。下面的 HelloForm.java Servlet程序使用GET和POST方法处理由Web浏览器给出的输入。

package com.xdl.form;

import java.io.IOException;

import java.io.PrintWriter;

import javax.servlet.ServletException;

import javax.servlet.http.HttpServlet;

import javax.servlet.http.HttpServletRequest;

import javax.servlet.http.HttpServletResponse;

public class HelloForm extends HttpServlet {

private static final long serialVersionUID = 1L;

public HelloForm() {

super();

}

protected void doGet(HttpServletRequest request,

HttpServletResponse response) throws ServletException, IOException {

response.setContentType("text/html;charset=UTF-8");

PrintWriter out = response.getWriter();

String title = "使用 POST 方法读取表单数据";

//在tomcat8中需要对POST提交的表单中的中文做处理,只有GET

String name =new String

(request.getParameter("name").getBytes ("ISO-8859-1"),"UTF-8");

//或者使用下面的方式进行中文乱码的处理,并且推荐使用这种方式

//request.setCharacterEncoding("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>");

}

public void doPost(HttpServletRequest request,

HttpServletResponse response) throws ServletException, IOException {

doGet(request, response);

}

}

现在将上面的Servlet重新部署到Tomcat服务器上并重启,然后使用带有POST方法的hello.html进行测试,hello.html代码如下:

<!DOCTYPE html>

<html>

<head>

<meta charset="utf-8">

<title>兄弟连it教育(java.itxdl.cn)</title>

</head>

<body>

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

网址名:<input type="text" name="name"> <br />

网址:<input type="text" name="url" />

<input type="submit" value="提交" />

</form>

</body>

</html>

在浏览器中输入http://localhost:8080/form-test/hello.html,然后输入网址名和网址,然后点击提交按钮,最后结果显示如图2所示。

HelloForm生成的HTML页面

现在我们需要使用复选框将数据传递到服务器端,首先我们新建一个HTML页面,checkbox.html,其中含有一个带有两个复选框的表单。

<!DOCTYPE html>

<html>

<head>

<meta charset="utf-8">

<title>兄弟连it教育(java.itxdl.cn)</title>

</head>

<body>

<form action="CheckBox" method="POST">

<input type="checkbox" name="itxdl" value="兄弟连IT教育" /> 兄弟连IT教育

<input type="checkbox" name="itxdl" value="Java" /> Java

<input type="checkbox" name="itxdl" value="大数据" /> 大数据

<input type="submit" value="选择站点" />

</form>

</body>

</html>

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

package com.xdl.form;

import java.io.IOException;

import java.io.PrintWriter;

import javax.servlet.ServletException;

import javax.servlet.http.HttpServlet;

import javax.servlet.http.HttpServletRequest;

import javax.servlet.http.HttpServletResponse;

public class CheckBox extends HttpServlet {

private static final long serialVersionUID = 1L;

protected void doGet(HttpServletRequest request,

HttpServletResponse response) throws ServletException, IOException {

request.setCharacterEncoding("UTF-8");

response.setContentType("text/html;charset=UTF-8");

PrintWriter out = response.getWriter();

String title = "读取复选框数据";

String[] parameterValues = request.getParameterValues("itxdl");

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" +

"您选择了:\n");

for(String name : parameterValues) {

out.println(name);

}

out.println(

"</ul>\n" +

"</body></html>");

}

public void doPost(HttpServletRequest request,

HttpServletResponse response) throws ServletException, IOException {

doGet(request, response);

}

}

设置对应的web.xml

<servlet>

<servlet-name>CheckBox</servlet-name>

<servlet-class>com.xdl.form.CheckBox</servlet-class>

</servlet>

<servlet-mapping>

<servlet-name>CheckBox</servlet-name>

<url-pattern>/CheckBox</url-pattern>

</servlet-mapping>

启动Tomcat服务器,然后再浏览器中输入http://localhost:8080/form-test/checkbox.html,将显示如图所示的页面。

checkbox.html

依次选择三个选项,然后点击"选择站点"按钮,将显示如图所示的页面。

CheckBox生成的HTML页面

IT兄弟连 JavaWeb教程 Servlet表单数据的更多相关文章

  1. IT兄弟连 JavaWeb教程 Servlet表单乱码问题

    在使用原生的Servlet进行Web应用开发时经常会遇到一些中文乱码问题,造成乱码问题的原因只有一个:即客户端与服务端的字符编码不一致所导致的. 请求参数乱码问题 服务器端获取客户端传递过来的数据出现 ...

  2. Servlet 表单数据

    很多情况下,需要传递一些信息,从浏览器到 Web 服务器,最终到后台程序.浏览器使用两种方法可将这些信息传递到 Web 服务器,分别为 GET 方法和 POST 方法. GET 方法 GET 方法向页 ...

  3. Servlet表单数据

    1.GET 方法 GET 方法向页面请求发送已编码的用户信息.页面和已编码的信息中间用 ? 字符分隔,如下所示: http://www.test.com/hello?key1=value1&k ...

  4. IT兄弟连 JavaWeb教程 Servlet

    Servlet的定义 Java Servlet是运行在Web服务器或应用服务器上的程序,它是作为来自Web浏览器或其他HTTP客户端的请求和HTTP服务器上的数据库或应用程序之间的中间层. 使用Ser ...

  5. IT兄弟连 HTML5教程 HTML5表单 小结及习题

    小结 HTML表单提交的方法有get方法和post方法,get方法的作用是从指定的资源请求数据,post方法的作用是向指定的资源提交要被处理的数据.HTML表单一直都是Web的核心技术之一,有了它我们 ...

  6. IT兄弟连 HTML5教程 HTML5表单 新增的表单属性1

    HTML5 Input表单为<form>和<input>标签添加了几个新属性,属性如表1. 1  autocomplete属性 autocomplete属性规定form或inp ...

  7. IT兄弟连 HTML5教程 HTML5表单 HTML5新增表单元素

    HTML5有一些新的表单元素:<datalist>.<keygen>.<output>.不是所有的浏览器都支持HTML5新的表单元素,但即使浏览器不支持该表单属性, ...

  8. IT兄弟连 HTML5教程 HTML5表单 HTML表单设计2

    5  隐藏域 隐藏域不会在表单中显示.如果需要在页面之间传递重要数据,则在<input>标签中设置type属性值为“hidden”建立一个隐藏域.name和value属性是必需的,用来表示 ...

  9. IT兄弟连 HTML5教程 HTML5表单 HTML表单设计1

    表单是PHP程序中最常使用的收集站点访问者信息的数据输入界面.通过表单浏览器获取用户的输入数据,并传送给Web服务器的脚本程序中,以各种不同的方式进行处理.在表单中提供了多种输入方式,包括文本输入域. ...

随机推荐

  1. 【Mongodb教程 第十八课 】MongoDB常用命令 数据库命令 集合操作命令

    面向文档的 NoSQL 数据库主要解决的问题不是高性能的并发读写,而是保证海量数据存储的同时,具有良好的查询性能.  条件操作符 <, <=, >, >=  这个操作符就不用多 ...

  2. 【转载】分布式RPC框架性能大比拼

    dubbo.motan.rpcx.gRPC.thrift的性能比较 Dubbo 是阿里巴巴公司开源的一个Java高性能优秀的服务框架,使得应用可通过高性能的 RPC 实现服务的输出和输入功能,可以和 ...

  3. JAVA WEB学习笔记(一):JDK的安装及环境变量的配置

    一.JDK的安装. JDK可以在Oracle(甲骨文)的官网下载,连接地址:http://www.oracle.com/technetwork/java/javase/downloads/index- ...

  4. openwrt hotplug

    由内核发出 event 事件. kobject_uevent() 产生 uevent 事件(lib/kobject_uevent.c 中), 产生的 uevent 先由 netlink_broadca ...

  5. Mono 和 .NET Core比翼双飞

    大家好,今天给大家分享.NET 蓝图之下的Mono和.NET Core 话题,微软在Build 2019 大会上给.NET 做了一个五年规划,所以分享的主题就是<Mono和.NET Core 比 ...

  6. vc6.0的一些快捷键

    1.检测程序中的括号是否匹配    把光标移动到需要检测的括号(如大括号{}.方括号[].圆括号()和尖括号<>)前面,键入快捷键“Ctrl+]”.如果括号匹配正确,光标就跳到匹配的括号处 ...

  7. C/C++ 操作符优先级

    不能光转贴,有空要熟悉之后,要写点心得.现在发现 . 的优先级确实很高. C: Precedence Operator Description Associativity 1 ++ -- Suffix ...

  8. DeepLearningFlappyBird-深度学习玩游戏-1-环境搭建

    -------------------------------------------------------------------------------------- https://githu ...

  9. Zookeeper原理和应用

    ZooKeeper基本原理 数据模型 如上图所示,ZooKeeper数据模型的结构与Unix文件系统很类似,整体上可以看作是一棵树,每个节点称做一个ZNode.每个ZNode都可以通过其路径唯一标识, ...

  10. uCOS-II模拟(VS2010&WIN32)

    转自http://www.amobbs.com/thread-5462878-1-1.html 自学uCOS-II源码,在论坛上上看到大神在WIN7 Visual Studio 2010环境下调试uC ...