很多情况下,需要传递一些信息,从浏览器到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. 小博客| 登录 | 注册 | 留言 | 提Bug 小博客

     浏览(1502)  赞(29) 一直以来都想开发一个自己的网站,总想做一个网站然后让千千万万的人去访问,去使用,然后收到热烈的好评, 再然后某某著名机构有意投资我的网站(其实收购也是没有问题的), ...

  2. 理解OpenStack认证:Keystone PKI

    原文链接: https://www.mirantis.com/blog/understanding-openstack-authentication-keystone-pki/ The latest ...

  3. SDOI2016R1(不是解题报告)

    话说洗澡的时候想了一堆要说的,坐到电脑前反而不知所措了-- 序章 听学长说他们都是省选一周前才停的课.然而我们这届--自聪哥韩大他们在省选两周前悄悄跑路后(据说班主任非常支持),信息小组内部一呼百应, ...

  4. appium server参数

    转自: http://m.blog.csdn.net/blog/kittyboy0001/40893979 appium Appium是一个开源的,适用于原生或混合移动应用应用( hybrid mob ...

  5. GDI泄露+改EXE名

    CDC 应该是成对使用 GetDC and ReleaseDC(不用new and delete) 泄露 1.改变生产exe名称:工程->设置->连接->输出文件名:Release/ ...

  6. HDU 6044 Limited Permutation 读入挂+组合数学

    Limited Permutation Problem Description As to a permutation p1,p2,⋯,pn from 1 to n, it is uncomplica ...

  7. 前端遇上Go: 静态资源增量更新的新实践

    前端遇上Go: 静态资源增量更新的新实践https://mp.weixin.qq.com/s/hCqQW1F8FngPPGZAisAWUg 前端遇上Go: 静态资源增量更新的新实践 原创: 洋河 美团 ...

  8. https://github.com/PyMySQL/PyMySQL/blob/master/pymysql/connections.py

    # Python implementation of the MySQL client-server protocol # http://dev.mysql.com/doc/internals/en/ ...

  9. bash_action

    https://stackoverflow.com/questions/12076326/how-to-install-maven2-on-redhat-linux #!/bin/bash # Tar ...

  10. 合肥 专业做APP(安卓,ios) 微信公共平台

    合肥 专业做APP(安卓,ios) 微信公共平台 电话:15715696592