Web服务器的HTTP应答一般由以下几项构成:一个状态行,一个或多个应答头,一个空行,内容文档。设置HTTP应答头往往和设置状态行中的状态代码结合起来。例如,有好几个表示“文档位置已经改变”的状态代码都伴随着一个Location头,而401(Unauthorized)状态代码则必须伴随一个WWW-Authenticate头。
下面为常见应答头及其含义 :
有关HTTP头详细和完整的说明,请参见http://www.w3.org/Protocols/ 规范。
Allow 服务器支持哪些请求方法(如GET、POST等)。
Content-Encoding 文档的编码(Encode)方法。只有在解码之后才可以得到Content-Type头指定的内容类型。利用gzip压缩文档能够显著地减少HTML文档的下载时间。Java的GZIPOutputStream可以很方便地进行gzip压缩,但只有Unix上的Netscape和Windows上的IE 4、IE 5才支持它。因此,Servlet应该通过查看Accept-Encoding头(即request.getHeader("Accept-Encoding"))检查浏览器是否支持gzip,为支持gzip的浏览器返回经gzip压缩的HTML页面,为其他浏览器返回普通页面。
Content-Length 表示内容长度。只有当浏览器使用持久HTTP连接时才需要这个数据。如果你想要利用持久连接的优势,可以把输出文档写入ByteArrayOutputStram,完成后查看其大小,然后把该值放入Content-Length头,最后通过byteArrayStream.writeTo(response.getOutputStream()发送内容。
Content-Type 表示后面的文档属于什么MIME类型。Servlet默认为text/plain,但通常需要显式地指定为text/html。由于经常要设置Content-Type,因此HttpServletResponse提供了一个专用的方法setContentTyep。
Date 当前的GMT时间。你可以用setDateHeader来设置这个头以避免转换时间格式的麻烦。
Expires 应该在什么时候认为文档已经过期,从而不再缓存它?
Last-Modified 文档的最后改动时间。客户可以通过If-Modified-Since请求头提供一个日期,该请求将被视为一个条件GET,只有改动时间迟于指定时间的文档才会返回,否则返回一个304(Not Modified)状态。Last-Modified也可用setDateHeader方法来设置。
Location 表示客户应当到哪里去提取文档。Location通常不是直接设置的,而是通过HttpServletResponse的sendRedirect方法,该方法同时设置状态代码为302。
Refresh 表示浏览器应该在多少时间之后刷新文档,以秒计。除了刷新当前文档之外,你还可以通过setHeader("Refresh", "5; URL=http://host/path")让浏览器读取指定的页面。
注意这种功能通常是通过设置HTML页面HEAD区的<META HTTP-EQUIV="Refresh" CONTENT="5;URL=http://host/path">实现,这是因为,自动刷新或重定向对于那些不能使用CGI或Servlet的HTML编写者十分重要。但是,对于Servlet来说,直接设置Refresh头更加方便。
注意Refresh的意义是“N秒之后刷新本页面或访问指定页面”,而不是“每隔N秒刷新本页面或访问指定页面”。因此,连续刷新要求每次都发送一个Refresh头,而发送204状态代码则可以阻止浏览器继续刷新,不管是使用Refresh头还是<META HTTP-EQUIV="Refresh" ...>。
注意Refresh头不属于HTTP 1.1正式规范的一部分,而是一个扩展,但Netscape和IE都支持它。
Set-Cookie 设置和页面关联的Cookie。Servlet不应使用response.setHeader("Set-Cookie", ...),而是应使用HttpServletResponse提供的专用方法addCookie。参见下文有关Cookie设置的讨论。
WWW-Authenticate 客户应该在Authorization头中提供什么类型的授权信息?在包含401(Unauthorized)状态行的应答中这个头是必需的。例如,response.setHeader("WWW-Authenticate", "BASIC realm=\"executives\"")。
注意Servlet一般不进行这方面的处理,而是让Web服务器的专门机制来控制受密码保护页面的访问(例如.htaccess)。
分享到:
相关推荐
### HTTP应答码详解 HTTP协议作为互联网上应用最为广泛的一种网络协议,其核心功能在于规范客户端与服务器间的数据交互过程。在这一过程中,HTTP应答码扮演着至关重要的角色,它不仅告知客户端请求的状态,还帮助...
8.1 HTTP应答头概述 Web服务器的HTTP应答一般由以下几项构成:一个状态行,一个或多个应答头,一个空行,内容文档。设置HTTP应答头往往和设置状态行中的状态代码结合起来。例如,有好几个表示“文档位置已经改变”的...
HTTP(Hypertext Transfer Protocol)协议是互联网上应用最广泛的一种网络协议,它定义了客户端(通常是Web浏览器)和服务器之间交互数据的格式和规则。HTTP协议基于客户/服务器模式,设计简洁快速,允许传输各种...
HTTP头域是指HTTP请求和响应报文中的头部部分,包括HTTP请求头域、HTTP应答头域、HTTP通用头域、HTTP实体头域等。 1. HTTP请求头域:包括Accept、Accept-Language、Accept-Encoding、User-Agent、Host、Connection...
- **200 OK**:最常见的成功应答,表明请求已被成功处理。具体响应取决于请求类型。 3. **转发请求(3xx)**: - **300 Multiple Choices**:请求的地址有多个选项,用户或 UA 需要选择一个合适的地址重新发送...
SIP 协议应答码是其通信过程中用来指示请求处理状态的关键部分,它沿袭并扩展了 HTTP/1.1 的应答码体系,同时也新增了一些特有的应答码。 1. **临时应答 (1xx)** - 1xx 应答码表示服务器正在处理请求,但尚未做出...
Http 消息头中常用的请求头和响应头 Http 消息头是指在 Http 请求和响应中添加的一些附加信息,以便于服务器和客户端之间的交互。这些附加信息可以是请求头、响应头、实体头等。 请求头是指客户端在向服务器发送...
* 不同于 HTTP,SIP 应答可以包含多个 Contact 头域或者一个 Contact 头域中具有一个地址列表。 * UA 可以使用 Contact 头域来自动转发或者要求用户确认转发。 * 本规范没有定义自动转发的标准。 * 如果被叫方可以在...
2. 应答改写则发生在AD设备接收服务器响应之后,但在转发给客户端之前,因此客户端可以看到明显的改写效果。 总的来说,HTTP头部改写是负载均衡解决方案中的一个重要组成部分,它能够帮助提升服务的可定制性和安全...
7.1 状态代码概述 Web服务器响应浏览器或其他客户程序的请求时,其应答一般由以下几个部分组成:一个状态行,几个应答头,一个空行,内容文档。下面是一个最简单的应答: ...
- **200 OK**: 最常见的成功应答,表示请求已被成功处理。 - 根据不同的请求方法,具体的含义可能有所不同。例如,在INVITE请求中,表示呼叫被接受。 #### 五、重定向应答 (3xx) **3xx** 应答指示客户端需要采取...
此功能分为请求改写和应答改写两部分,分别处理客户端发起的HTTP请求和服务器返回的HTTP响应。 1. **HTTP头部** - **请求改写**:涉及请求行的VERSION、METHOD、URI,以及请求头部的HOST、COOKIE、USER-AGENT字段...
HTTP应答同样由三部分组成:状态行、应答头和应答正文。 - **状态行**包括协议版本、状态码和状态描述,如“HTTP/1.1 200 OK”。其中,“200”表示请求成功。 - **应答头**提供关于服务器和应答的元数据,如服务器...
而应答改写则发生在AD设备收到服务器响应之后,但在发送给客户端之前,客户端能够明显看到结果。 总之,HTTP头部改写是负载均衡服务器中的一个重要功能,它能够帮助解决IP识别、动态内容分发以及安全防护等问题。...
应答头 说明 Allow 服务器支持哪些请求方法(如GET、POST等)。 Content-Encoding 文档的编码(Encode)方法。只有在解码之后才可以得到Content-Type头指定的内容类型。利用gzip压缩文档能够显著地减少...
如果服务器提出要优先选择,则应该在 Location 应答头中指明。 301:客户请求的文档在其他地方,新的 URL 在 Location 头中给出,浏览器应该自动访问新的 URL。 302:类似于 301,但新的 URL 应该被视为临时性的...
简单的 HTTP1.0 客户端程序能够接受服务器响应,在命令行上显示出服务器的应答头部,把服务器的应答内容保存在一个文件中;服务器能实现对所有的请求给予应答,其中要求对HTTP 的GET 方法根据RFC 规定给予成功的响应...
2. 应答改写发生在AD收到服务器的回应之后,发送给客户端之前,客户端一定可以看出效果。 深信服AD负载HTTP头部改写技术可以解决多种场景下的问题,例如让服务器看到客户端的真实IP、实现基于IP地址的用户定向、...