©
Ce document utiliseManuel du site Web PHP chinoisLibérer
当浏览器请求一个网页时,它会向网络服务器发送一系列不能被直接读取的信息,因为这些信息是作为HTTP信息头的一部分来传送的。您可以查阅HTTP协议来获得更多的信息。
下表列出了浏览器端信息头的一些重要内容,在以后的网络编程中将会经常见到这些信息:
信息 | 描述 |
---|---|
Accept | 指定浏览器或其他客户端可以处理的MIME类型。它的值通常为image/png或image/jpeg |
Accept-Charset | 指定浏览器要使用的字符集。比如 ISO-8859-1 |
Accept-Encoding | 指定编码类型。它的值通常为gzip或compress |
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 | 用来区分不同浏览器或客户端发送的请求,并对不同类型的浏览器返回不同的内容 |
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()返回服务器端口号 |
在这个例子中,我们会使用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(" Header Name Header Value(s) \n"); } %> " + paramName + " \n"); String paramValue = request.getHeader(paramName); out.println("" + paramValue + "
访问main.jsp,将会得到以下结果:
Header Name | Header Value(s) | ||||||||||||||||||||||||||
---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
accept | * } } 编译LogFilter.java文件,然后将编译后的class文件放在 web.xml文件中的JSP过滤器映射过滤器被定义,然后映射成一个URL或JSP文件名,与servlet被定义然后映射的方式差不多。在部署描述文件web.xml中,使用
JSP脚本通过request对象中的getCookies()方法来访问这些cookies,这个方法会返回一个Cookie对象的数组。 Servlet Cookies 方法下表列出了Cookie对象中常用的方法:
使用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 ); %>
将上面两个文件放在 试着输入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。
如果您把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,按照下面给的步骤来做就行了:
实例演示下面的程序删除一个名为"first_name"的cookie,当您下次运行main.jsp时,first_name将会为null。
访问它,将会得到如下输出结果: 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了。 关于我们 联系我们 留言板 手册网 |