Figuren

JSP 客户端请求


当浏览器请求一个网页时,它会向网络服务器发送一系列不能被直接读取的信息,因为这些信息是作为HTTP信息头的一部分来传送的。您可以查阅HTTP协议来获得更多的信息。

下表列出了浏览器端信息头的一些重要内容,在以后的网络编程中将会经常见到这些信息:

信息 描述
Accept 指定浏览器或其他客户端可以处理的MIME类型。它的值通常为image/pngimage/jpeg
Accept-Charset 指定浏览器要使用的字符集。比如 ISO-8859-1
Accept-Encoding 指定编码类型。它的值通常为gzipcompress
Accept-Language 指定客户端首选语言,servlet会优先返回以当前语言构成的结果集,如果servlet支持这种语言的话。比如 en,en-us,ru等等
Authorization 在访问受密码保护的网页时识别不同的用户
Connection 表明客户端是否可以处理HTTP持久连接。持久连接允许客户端或浏览器在一个请求中获取多个文件。Keep-Alive表示启用持久连接
Content-Length 仅适用于POST请求,表示 POST 数据的字节数
Cookie 返回先前发送给浏览器的cookies至服务器
Host 指出原始URL中的主机名和端口号
If-Modified-Since 表明只有当网页在指定的日期被修改后客户端才需要这个网页。 服务器发送304码给客户端,表示没有更新的资源
If-Unmodified-Since 与If-Modified-Since相反, 只有文档在指定日期后仍未被修改过,操作才会成功
Referer 标志着所引用页面的URL。比如,如果你在页面1,然后点了个链接至页面2,那么页面1的URL就会包含在浏览器请求页面2的信息头中
User-Agent 用来区分不同浏览器或客户端发送的请求,并对不同类型的浏览器返回不同的内容

HttpServletRequest类

request对象是javax.servlet.http.HttpServletRequest类的实例。每当客户端请求一个页面时,JSP引擎就会产生一个新的对象来代表这个请求。

request对象提供了一系列方法来获取HTTP信息头,包括表单数据,cookies,HTTP方法等等。

接下来将会介绍一些在JSP编程中常用的获取HTTP信息头的方法。详细内容请见下表:

序号 方法&描述
1 Cookie[] getCookies()返回客户端所有的Cookie的数组
2 Enumeration getAttributeNames()返回request对象的所有属性名称的集合
3 Enumeration getHeaderNames()返回所有HTTP头的名称集合
4 Enumeration getParameterNames()返回请求中所有参数的集合
5 HttpSession getSession()返回request对应的session对象,如果没有,则创建一个
6 HttpSession getSession(boolean create)返回request对应的session对象,如果没有并且参数create为true,则返回一个新的session对象
7 Locale getLocale()返回当前页的Locale对象,可以在response中设置
8 Object getAttribute(String name)返回名称为name的属性值,如果不存在则返回null。
9 ServletInputStream getInputStream()返回请求的输入流
10 String getAuthType()返回认证方案的名称,用来保护servlet,比如 "BASIC" 或者 "SSL" 或 null 如果 JSP没设置保护措施
11 String getCharacterEncoding()返回request的字符编码集名称
12 String getContentType()返回request主体的MIME类型,若未知则返回null
13 String getContextPath()返回request URI中指明的上下文路径
14 String getHeader(String name)返回name指定的信息头
15 String getMethod()返回此request中的HTTP方法,比如 GET,,POST,或PUT
16 String getParameter(String name)返回此request中name指定的参数,若不存在则返回null
17 String getPathInfo()返回任何额外的与此request URL相关的路径
18 String getProtocol()返回此request所使用的协议名和版本
19 String getQueryString()返回此 request URL包含的查询字符串
20 String getRemoteAddr()返回客户端的IP地址
21 String getRemoteHost()返回客户端的完整名称
22 String getRemoteUser()返回客户端通过登录认证的用户,若用户未认证则返回null
23 String getRequestURI()返回request的URI
24 String getRequestedSessionId()返回request指定的session ID
25 String getServletPath()返回所请求的servlet路径
26 String[] getParameterValues(String name)返回指定名称的参数的所有值,若不存在则返回null
27 boolean isSecure()返回request是否使用了加密通道,比如HTTPS
28 int getContentLength()返回request主体所包含的字节数,若未知的返回-1
29 int getIntHeader(String name)返回指定名称的request信息头的值
30 int getServerPort()返回服务器端口号

HTTP信息头示例

在这个例子中,我们会使用HttpServletRequest类的getHeaderNames()方法来读取HTTP信息头。这个方法以枚举的形式返回当前HTTP请求的头信息。

获取Enumeration对象后,用标准的方式来遍历Enumeration对象,用hasMoreElements()方法来确定什么时候停止,用nextElement()方法来获得每个参数的名字。

<%@ page import="java.io.*,java.util.*" %>   HTTP Header Request Example 

HTTP Header Request Example

<% Enumeration headerNames = request.getHeaderNames(); while(headerNames.hasMoreElements()) { String paramName = (String)headerNames.nextElement(); out.print("\n"); String paramValue = request.getHeader(paramName); out.println("\n"); } %>
Header NameHeader Value(s)
" + paramName + " " + paramValue + "

访问main.jsp,将会得到以下结果:

Header Name Header Value(s)
accept * } }

编译LogFilter.java文件,然后将编译后的class文件放在/webapps/ROOT/WEB-INF/classes目录下。


web.xml文件中的JSP过滤器映射

过滤器被定义,然后映射成一个URL或JSP文件名,与servlet被定义然后映射的方式差不多。在部署描述文件web.xml中,使用标签来进行过滤器映射:

 LogFilter LogFilter  test-param Initialization Paramter    LogFilter * Accept-Encoding: gzip Accept-Language: en Accept-Charset: iso-8859-1,*,utf-8 Cookie: name=xyz

JSP脚本通过request对象中的getCookies()方法来访问这些cookies,这个方法会返回一个Cookie对象的数组。


Servlet Cookies 方法

下表列出了Cookie对象中常用的方法:

序号 方法&描述
1 public void setDomain(String pattern)设置cookie的域名,比如shouce.ren
2 public String getDomain()获取cookie的域名,比如shouce.ren
3 public void setMaxAge(int expiry)设置cookie有效期,以秒为单位,默认有效期为当前session的存活时间
4 public int getMaxAge()获取cookie有效期,以秒为单位,默认为-1 ,表明cookie会活到浏览器关闭为止
5 public String getName()返回 cookie的名称,名称创建后将不能被修改
6 public void setValue(String newValue)设置 cookie的值
7 public String getValue()获取cookie的值
8 public void setPath(String uri)设置cookie 的路径,默认为当前页面目录下的所有URL,还有此目录下的所有子目录
9 public String getPath()获取cookie 的路径
10 public void setSecure(boolean flag)指明cookie是否要加密传输
11 public void setComment(String purpose)设置注释描述 cookie的目的。当浏览器将cookie展现给用户时,注释将会变得非常有用
12 public String getComment()返回描述cookie目的的注释,若没有则返回null

使用JSP设置Cookies

使用JSP设置cookie包含三个步骤:

(1)创建一个Cookie对象:调用Cookie的构造函数,使用一个cookie名称和值做参数,它们都是字符串。

Cookie cookie = new Cookie("key","value");

请务必牢记,名称和值中都不能包含空格或者如下的字符:

[ ] ( ) = , " / ? @ : ;

(2) 设置有效期:调用setMaxAge()函数表明cookie在多长时间(以秒为单位)内有效。下面的操作将有效期设为了24小时。

cookie.setMaxAge(60*60*24);

(3) 将cookie发送至HTTP响应头中:调用response.addCookie()函数来向HTTP响应头中添加cookies。

response.addCookie(cookie);

实例演示

<% // 为 first_name 和 last_name设置cookie Cookie firstName = new Cookie("first_name", request.getParameter("first_name")); Cookie lastName = new Cookie("last_name", request.getParameter("last_name")); // 设置cookie过期时间为24小时。 firstName.setMaxAge(60*60*24); lastName.setMaxAge(60*60*24); // 在响应头部添加cookie response.addCookie( firstName ); response.addCookie( lastName ); %>   Setting Cookies 

Setting Cookies

  • First Name: <%= request.getParameter("first_name")%>

  • Last Name: <%= request.getParameter("last_name")%>

将上面两个文件放在/webapps/ROOT目录下,然后访问http://localhost:8080/hello.jsp,将会得到如下输出结果:

试着输入First Name和Last Name,然后点击提交按钮,它将会在您的屏幕中显示first name和last name,并且设置first name和last name两个cookie,下一次点击提交按钮时会发给服务器。


使用JSP读取Cookies

想要读取cookies,您就需要调用request.getCookies()方法来获得一个javax.servlet.http.Cookie对象的数组,然后遍历这个数组,使用getName()方法和getValue()方法来获取每一个cookie的名称和值。

让我们来读取上个例子中的cookies。

  Reading Cookies 

Reading Cookies

<% Cookie cookie = null; Cookie[] cookies = null; // 获取cookies的数据,是一个数组 cookies = request.getCookies(); if( cookies != null ){ out.println("

Found Cookies Name and Value

"); for (int i = 0; i < cookies.length; i++){ cookie = cookies[i]; out.print("Name : " + cookie.getName( ) + ", "); out.print("Value: " + cookie.getValue( )+"
"); } }else{ out.println("

No cookies founds

"); } %>

如果您把first name cookie设置成"John",last name设置成"Player",访问 http://localhost:8080/main.jsp,将会得到如下输出结果:

Found Cookies Name and Value Name : first_name, Value: John Name : last_name, Value: Player

使用JSP删除Cookies

删除cookies非常简单。如果您想要删除一个cookie,按照下面给的步骤来做就行了:

  • 获取一个已经存在的cookie然后存储在Cookie对象中。
  • 将cookie的有效期设置为0。
  • 将这个cookie重新添加进响应头中。

实例演示

下面的程序删除一个名为"first_name"的cookie,当您下次运行main.jsp时,first_name将会为null。

  Reading Cookies 

Reading Cookies

<% Cookie cookie = null; Cookie[] cookies = null; // 获取当前域名下的cookies,是一个数组 cookies = request.getCookies(); if( cookies != null ){ out.println("

Found Cookies Name and Value

"); for (int i = 0; i < cookies.length; i++){ cookie = cookies[i]; if((cookie.getName( )).compareTo("first_name") == 0 ){ cookie.setMaxAge(0); response.addCookie(cookie); out.print("Deleted cookie: " + cookie.getName( ) + "
"); } out.print("Name : " + cookie.getName( ) + ", "); out.print("Value: " + cookie.getValue( )+"
"); } }else{ out.println( "

No cookies founds

"); } %>

访问它,将会得到如下输出结果:

Cookies Name and Value Deleted cookie : first_name Name : first_name, Value: John Name : last_name, Value: Player

再次访问http://localhost:8080/main.jsp,将会得到如下结果:

Found Cookies Name and Value Name : last_name, Value: Player

您也可以手动在浏览器中删除cookies。点击Tools菜单项,然后选择Internet Options,点击Delete Cookies,就能删除所有cookies了。

关于我们 联系我们 留言板

手册网

Vorheriger Artikel: Nächster Artikel: