header头部域
HTTP (HyperTextTransferProtocol )是超文本传输协议的缩写,它用于传送WWW 方式的数据,关于HTTP 协议的详细内容请参考RFC2616。HTTP 协议采用了请求/响应
HTTP (HyperTextTransferProtocol )是超文本传输协议的缩写,它用于传送WWW 方式的数据,关于HTTP 协议的详细内容请参考RFC2616。HTTP 协议采用了请求/响应模型。客户端向服务器发送一个请求,请求头包含请求的方法、URI 、协议版本、以及包含请求修饰符、客户信息和内容的类似于MIME 的消息结构。服务器以一个状态行作为响应,相应的内容包括消息协议的版本,成功或者错误编码加上包含服务器信息、实体元信息以及可能的实体内容。
通常HTTP 消息包括客户机向服务器的请求消息和服务器向客户机的响应消息。这两种类型的消息由一个起始行,一个或者多个头域,一个只是头域结束的空行和可选的消息体组成。HTTP 的头域包括通用头,请求头,响应头和实体头四个部分。每个头域由一个域名,冒号(:)和域值三部分组成。域名是大小写无关的,域值前可以添加任何数量的空格符,头域可以被扩展为多行,在每行开始处,使用至少一个空格或制表符。
通用头域
通用头域包含请求和响应消息都支持的头域,通用头域包含Cache-Control 、Connection 、Date 、Pragma 、Transfer-Encoding 、Upgrade 、Via 。对通用头域的扩展要求通讯双方都支持此扩展,如果存在不支持的通用头域,一般将会作为实体头域处理。下面简单介绍几个在UPnP 消息中使用的通用头域。 Cache-Control 头域
Cache-Control 指定请求和响应遵循的缓存机制。在请求消息或响应消息中设置Cache-Control 并不会修改另一个消息处理过程中的缓存处理过程。请求时的缓存指令包括no-cache 、no-store 、max-age 、max-stale 、min-fresh 、only-if-cached ,响应消息中的指令包括public 、private 、no-cache 、no-store 、no-transform 、must-revalidate 、proxy-revalidate 、max-age 。各个消息中的指令含义如下:
Public 指示响应可被任何缓存区缓存。
Private 指示对于单个用户的整个或部分响应消息,不能被共享缓存处理。这允许服务器仅仅描述当用户的部分响应消息,此响应消息对于其他用户的请求无效。
no-cache 指示请求或响应消息不能缓存
no-store 用于防止重要的信息被无意的发布。在请求消息中发送将使得请求和响应消息都不使用缓存。 max-age 指示客户机可以接收生存期不大于指定时间(以秒为单位)的响应。
min-fresh 指示客户机可以接收响应时间小于当前时间加上指定时间的响应。
max-stale 指示客户机可以接收超出超时期间的响应消息。如果指定max-stale 消息的值,那么客户机可以接收超出超时期指定值之内的响应消息。
Date 头域
Date 头域表示消息发送的时间,时间的描述格式由rfc822定义。例如,
Date:Mon,31Dec200104:25:57GMT。Date 描述的时间表示世界标准时,换算成本地时间,需要知道用户所在的时区。
Pragma 头域
Pragma 头域用来包含实现特定的指令,最常用的是Pragma:no-cache。在HTTP/1.1协议中,它的含义和Cache-Control:no-cache相同。
请求消息
请求消息的第一行为下面的格式:
MethodSPRequest-URISPHTTP-VersionCRLFMethod 表示对于Request-URI 完成的方法,这个字段是大小写敏感的,包括OPTIONS 、GET 、HEAD 、POST 、PUT 、DELETE 、TRACE 。方法GET 和HEAD 应该被所有的通用WEB 服务器支持,其他所有方法的实现是可选的。GET 方法取回由Request-URI 标识的信息。HEAD 方法也是取回由Request-URI 标识的信息,只是可以在响应时,不返回消息体。POST 方法可以请求服务器接收包含在请求中的实体信息,可以用于提交表单,向新闻组、BBS 、邮件群组和数据库发送消息。
,SP 表示空格。Request-URI 遵循URI 格式,在此字段为星号(*)时,说明请求并不用于某个特定的资源地址,而是用于服务器本身。HTTP-Version 表示支持的HTTP 版本,例如为HTTP/1.1。CRLF 表示换行回车符。请求头域允许客户端向服务器传递关于请求或者关于客户机的附加信息。请求头域可能包含下列字段Accept 、Accept-Charset 、Accept-Encoding 、Accept-Language 、Authorization 、From 、Host 、If-Modified-Since 、If-Match 、If-None-Match 、If-Range 、If-Range 、If-Unmodified-Since 、Max-Forwards 、Proxy-Authorization 、Range 、Referer 、User-Agent 。对请求头域的扩展要求通讯双方都支持,如果存在不支持的请求头域,一般将会作为实体头域处理。
典型的请求消息:
GEThttp://class/download.microtool.de:80/somedata.exe
Host:download.microtool.de
Accept:*/*
Pragma:no-cache
Cache-Control:no-cache
Referer:http://class/download.microtool.de/
User-Agent:Mozilla/4.04[en](Win95;I;Nav)
Range:bytes=554554-
上例第一行表示HTTP 客户端(可能是浏览器、下载程序)通过GET 方法获得指定URL 下的文件。棕色的部分表示请求头域的信息,绿色的部分表示通用头部分。
Host 头域
Host 头域指定请求资源的Intenet 主机和端口号,必须表示请求url 的原始服务器或网关的位置。HTTP/1.1请求必须包含主机头域,否则系统会以400状态码返回。
Referer 头域
Referer 头域允许客户端指定请求uri 的源资源地址,这可以允许服务器生成回退链表,可用来登陆、优化cache 等。他也允许废除的或错误的连接由于维护的目的被追踪。如果请求的uri 没有自己的uri 地址,Referer 不能被发送。如果指定的是部分uri 地址,则此地址应该是一个相对地址。
Range 头域
Range 头域可以请求实体的一个或者多个子范围。例如,
表示头500个字节:bytes=0-499
表示第二个500字节:bytes=500-999
表示最后500个字节:bytes=-500
表示500字节以后的范围:bytes=500-
第一个和最后一个字节:bytes=0-0,-1
同时指定几个范围:bytes=500-600,601-999
但是服务器可以忽略此请求头,如果无条件GET 包含Range 请求头,响应会以状态码206(PartialContent )返回而不是以200(OK )。
User-Agent 头域
User-Agent 头域的内容包含发出请求的用户信息。
响应消息
响应消息的第一行为下面的格式:
HTTP-VersionSPStatus-CodeSPReason-PhraseCRLF
HTTP-Version 表示支持的HTTP 版本,例如为HTTP/1.1。Status-Code 是一个三个数字的结果代码。Reason-Phrase 给Status-Code 提供一个简单的文本描述。Status-Code 主要用于机器自动识别,
Reason-Phrase 主要用于帮助用户理解。Status-Code 的第一个数字定义响应的类别,后两个数字没有分类的作用。第一个数字可能取5个不同的值:
,1xx:信息响应类,表示接收到请求并且继续处理
2xx:处理成功响应类,表示动作被成功接收、理解和接受
3xx:重定向响应类,为了完成指定的动作,必须接受进一步处理
4xx:客户端错误,客户请求包含语法错误或者是不能正确执行
5xx:服务端错误,服务器不能正确执行一个正确的请求
响应头域允许服务器传递不能放在状态行的附加信息,这些域主要描述服务器的信息和Request-URI 进一步的信息。响应头域包含Age 、Location 、Proxy-Authenticate 、Public 、Retry-After 、Server 、Vary 、Warning 、WWW-Authenticate 。对响应头域的扩展要求通讯双方都支持,如果存在不支持的响应头域,一般将会作为实体头域处理。
典型的响应消息:
HTTP/1.0200OK
Date:Mon,31Dec200104:25:57GMT
Server:Apache/1.3.14(Unix)
Content-type:text/html
Last-modified:Tue,17Apr200106:46:28GMT
Etag:"a030f020ac7c01:1e9f"
Content-length:39725426
Content-range:bytes554554-40279979/40279980
上例第一行表示HTTP 服务端响应一个GET 方法。棕色的部分表示响应头域的信息,绿色的部分表示通用头部分,红色的部分表示实体头域的信息。
Location 响应头
Location 响应头用于重定向接收者到一个新URI 地址。
Server 响应头
Server 响应头包含处理请求的原始服务器的软件信息。此域能包含多个产品标识和注释,产品标识一般按照重要性排序。
实体
请求消息和响应消息都可以包含实体信息,实体信息一般由实体头域和实体组成。实体头域包含关于实体的原信息,实体头包括Allow 、Content-Base 、Content-Encoding 、Content-Language 、Content-Length 、Content-Location 、Content-MD5、Content-Range 、Content-Type 、Etag 、Expires 、Last-Modified 、extension-header 。extension-header 允许客户端定义新的实体头,但是这些域可能无法未接受方识别。实体可以是一个经过编码的字节流,它的编码方式由Content-Encoding 或Content-Type 定义,它的长度由Content-Length 或Content-Range 定义。
Content-Type 实体头
用于向接收方指示实体的介质类型,指定HEAD 方法送到接收方的实体介质类型,或GET 方法发送的请求介质类型Content-Range 实体头
Content-Range 实体头
用于指定整个实体中的一部分的插入位置,他也指示了整个实体的长度。在服务器向客户返回一个部分响应,它必须描述响应覆盖的范围和整个实体长度。一般格式:
Content-Range:bytes-unitSPfirst-byte-pos-last-byte-pos/entity-legth
例如,传送头500个字节次字段的形式:Content-Range:bytes0-499/1234如果一个http 消息包含此节(例如,对范围请求的响应或对一系列范围的重叠请求),Content-Range 表示传送的范围,Content-Length 表示实际传送的字节数。
Last-modified 实体头
指定服务器上保存内容的最后修订时间。
,HTTP (HyperTextTransferProtocol )是超文本传输协议的缩写,它用于传送WWW 方式的数据,关于HTTP 协议的详细内容请参考RFC2616。HTTP 协议采用了请求/响应模型。客户端向服务器发送一个请求,请求头包含请求的方法、URI 、协议版本、以及包含请求修饰符、客户信息和内容的类似于MIME 的消息结构。服务器以一个状态行作为响应,相应的内容包括消息协议的版本,成功或者错误编码加上包含服务器信息、实体元信息以及可能的实体内容。
通常HTTP 消息包括客户机向服务器的请求消息和服务器向客户机的响应消息。这两种类型的消息由一个起始行,一个或者多个头域,一个只是头域结束的空行和可选的消息体组成。HTTP 的头域包括通用头,请求头,响应头和实体头四个部分。每个头域由一个域名,冒号(:)和域值三部分组成。域名是大小写无关的,域值前可以添加任何数量的空格符,头域可以被扩展为多行,在每行开始处,使用至少一个空格或制表符。
1. Accept:告诉WEB 服务器自己接受什么介质类型,*/* 表示任何类型,type/* 表示该类型下的所有子类型,type/sub-type。
2. Accept-Charset: 浏览器申明自己接收的字符集
Accept-Encoding : 浏览器申明自己接收的编码方法,通常指定压缩方法,是否支持压缩,支持什么压缩方法(gzip ,deflate )
Accept-Language ::浏览器申明自己接收的语言
语言跟字符集的区别:中文是语言,中文有多种字符集,比如big5,gb2312,gbk 等等。
3. Accept-Ranges:WEB 服务器表明自己是否接受获取其某个实体的一部分(比如文件的一部分)的请求。 bytes :表示接受,none :表示不接受。
4. Age:当代理服务器用自己缓存的实体去响应请求时,用该头部表明该实体从产生到现在经过多长时间了。
5. Authorization:当客户端接收到来自WEB 服务器的 WWW-Authenticate 响应时,用该头部来回应自己的身份验证信息给WEB 服务器。
6. Cache-Control:请求:no-cache (不要缓存的实体,要求现在从WEB 服务器去取)
max-age :(只接受 Age 值小于 max-age 值,并且没有过期的对象)
max-stale :(可以接受过去的对象,但是过期时间必须小于 max-stale 值)
min-fresh :(接受其新鲜生命期大于其当前 Age 跟 min-fresh 值之和的缓存对象)
响应:public(可以用 Cached 内容回应任何用户)
private (只能用缓存内容回应先前请求该内容的那个用户)
no-cache (可以缓存,但是只有在跟WEB 服务器验证了其有效后,才能返回给客户端)
max-age :(本响应包含的对象的过期时间)
ALL: no-store(不允许缓存)
7. Connection:请求:close (告诉WEB 服务器或者代理服务器,在完成本次请求的响应后,断开连接,不要等待本次连接的后续请求了)。
keepalive (告诉WEB 服务器或者代理服务器,在完成本次请求的响应后,保持连接,等待本次连接的后续请求)。
响应:close (连接已经关闭)。
keepalive (连接保持着,在等待本次连接的后续请求)。
Keep-Alive :如果浏览器请求保持连接,则该头部表明希望 WEB 服务器保持连接多长时间(秒)。 例如:Keep-Alive :300
8. Content-Encoding:WEB 服务器表明自己使用了什么压缩方法(gzip ,deflate )压缩响应中的对象。 例如:Content-Encoding :gzip
Content-Language :WEB 服务器告诉浏览器自己响应的对象的语言。
Content-Length : WEB 服务器告诉浏览器自己响应的对象的长度。
,例如:Content-Length: 26012
Content-Range : WEB 服务器表明该响应包含的部分对象为整个对象的哪个部分。
例如:Content-Range: bytes 21010-47021/47022
Content-Type : WEB 服务器告诉浏览器自己响应的对象的类型。
例如:Content-Type :application/xml
9. ETag:就是一个对象(比如URL )的标志值,就一个对象而言,比如一个 html 文件,如果被修改了,其 Etag 也会别修改,
所以,ETag 的作用跟 Last-Modified 的作用差不多,主要供 WEB 服务器判断一个对象是否改变了。 比如前一次请求某个 html 文件时,获得了其 ETag ,当这次又请求这个文件时,浏览器就会把先前获得的 ETag 值发送给
WEB 服务器,然后 WEB 服务器会把这个 ETag 跟该文件的当前 ETag 进行对比,然后就知道这个文件有没有改变了。
10. Expired:WEB 服务器表明该实体将在什么时候过期,对于过期了的对象,只有在跟WEB 服务器验证了其有效性后,才能用来响应客户请求。
是 HTTP/1.0 的头部。
例如:Expires :Sat, 23 May 2009 10:02:12 GMT
11. Host:客户端指定自己想访问的WEB 服务器的域名/IP 地址和端口号。
例如:Host :rss.sina.com.cn
12. If-Match:如果对象的 ETag 没有改变,其实也就意味著对象没有改变,才执行请求的动作。 If-None-Match :如果对象的 ETag 改变了,其实也就意味著对象也改变了,才执行请求的动作。
13. If-Modified-Since:如果请求的对象在该头部指定的时间之后修改了,才执行请求的动作(比如返回对象),否则返回代码304,告诉浏览器该对象没有修改。
例如:If-Modified-Since :Thu, 10 Apr 2008 09:14:42 GMT
If-Unmodified-Since :如果请求的对象在该头部指定的时间之后没修改过,才执行请求的动作(比如返回对象)。
14. If-Range:浏览器告诉 WEB 服务器,如果我请求的对象没有改变,就把我缺少的部分给我,如果对象改变了,就把整个对象给我。
浏览器通过发送请求对象的 ETag 或者 自己所知道的最后修改时间给 WEB 服务器,让其判断对象是否改变了。
总是跟 Range 头部一起使用。
15. Last-Modified:WEB 服务器认为对象的最后修改时间,比如文件的最后修改时间,动态页面的最后产生时间等等。
例如:Last-Modified :Tue, 06 May 2008 02:42:43 GMT
16. Location:WEB 服务器告诉浏览器,试图访问的对象已经被移到别的位置了,到该头部指定的位置去取。
例如:Location :
17. Pramga:主要使用 Pramga: no-cache,相当于 Cache-Control : no-cache 。
例如:Pragma :no-cache
18. Proxy-Authenticate: 代理服务器响应浏览器,要求其提供代理身份验证信息。
Proxy-Authorization :浏览器响应代理服务器的身份验证请求,提供自己的身份信息。
19. Range:浏览器(比如 Flashget 多线程下载时)告诉 WEB 服务器自己想取对象的哪部分。 例如:Range: bytes=1173546-
,20. Referer:浏览器向 WEB 服务器表明自己是从哪个 网页/URL 获得/点击 当前请求中的网址/URL。 例如:Referer :http://www.sina.com/
21. Server: WEB 服务器表明自己是什么软件及版本等信息。
例如:Server :Apache/2.0.61 (Unix)
22. User-Agent: 浏览器表明自己的身份(是哪种浏览器)。
例如:User-Agent :Mozilla/5.0 (Windows; U; Windows NT 5.1; zh-CN; rv:1.8.1.14) Gecko/20080404 Firefox/2.0.0.14
23. Transfer-Encoding: WEB 服务器表明自己对本响应消息体(不是消息体里面的对象)作了怎样的编码,比如是否分块(chunked )。
例如:Transfer-Encoding: chunked
24. Vary: WEB服务器用该头部的内容告诉 Cache 服务器,在什么条件下才能用本响应所返回的对象响应后续的请求。
假如源WEB 服务器在接到第一个请求消息时,其响应消息的头部为:Content-Encoding: gzip; Vary: Content-Encoding
那么 Cache 服务器会分析后续请求消息的头部,检查其 Accept-Encoding ,是否跟先前响应的 Vary 头部值一致,即是否使用
相同的内容编码方法,这样就可以防止 Cache 服务器用自己 Cache 里面压缩后的实体响应给不具备解压能力的浏览器。
例如:Vary :Accept-Encoding
25. Via: 列出从客户端到 OCS 或者相反方向的响应经过了哪些代理服务器,他们用什么协议(和版本)发送的请求。
当客户端请求到达第一个代理服务器时,该服务器会在自己发出的请求里面添加 Via 头部,并填上自己的相关信息,当下一个代理服务器
收到第一个代理服务器的请求时,会在自己发出的请求里面复制前一个代理服务器的请求的Via 头部,并把自己的相关信息加到后面,
以此类推,当 OCS 收到最后一个代理服务器的请求时,检查 Via 头部,就知道该请求所经过的路由。 例如:Via :1.0 236-81.D07071953.sina.com.cn:80 (squid/2.6.STABLE13)
============================================================================================================================
HTTP 请求消息头部实例:
Host :rss.sina.com.cn
User-Agent :Mozilla/5.0 (Windows; U; Windows NT 5.1; zh-CN; rv:1.8.1.14) Gecko/20080404 Firefox/2.0.0.14
Accept :
text/xml,application/xml,application/xhtml xml,text/html;q=0.9,text/plain;q=0.8,image/png,*/*;q=0.5 Accept-Language :zh-cn,zh;q=0.5
Accept-Encoding :gzip,deflate
Accept-Charset :gb2312,utf-8;q=0.7,*;q=0.7
Keep-Alive :300
Connection :keep-alive
Cookie :userId=C5bYpXrimdmsiQmsBPnE1Vn8ZQmdWSm3WRlEB3vRwTnRtW <-- Cookie
If-Modified-Since :Sun, 01 Jun 2008 12:05:30 GMT
Cache-Control :max-age=0
HTTP 响应消息头部实例:
,Status :OK - 200 <-- 响应状态码,表示 web 服务器处理的结果。
Date :Sun, 01 Jun 2008 12:35:47 GMT
Server :Apache/2.0.61 (Unix)
Last-Modified :Sun, 01 Jun 2008 12:35:30 GMT
Accept-Ranges :bytes
Content-Length :18616
Cache-Control :max-age=120
Expires :Sun, 01 Jun 2008 12:37:47 GMT
Content-Type :application/xml
Age :2
X-Cache :HIT from 236-41.D07071951.sina.com.cn <-- 反向代理服务器使用的 HTTP 头部 Via :1.0 236-41.D07071951.sina.com.cn:80 (squid/2.6.STABLE13)
Connection :close
(HTTP 协议完整规范参见W3C 官方网站http://www.w3.org/Protocols/)
==============
HTTP 头字段包括4类:
general-header ;
request-header ;
response-header ;
entity-header .
*******************************************************************************
General Header Fields
=============================
general header是request 、response 都可用的, 但是不能用于entity.
-- Cache-Control
-- Connection
-- Date
-- Pragma
-- Trailer
-- Transfer-Encoding
-- Upgrade
,-- Via
-- Warning
*******************************************************************************
Request Header Fields
======================
request-header fields 允许客户端传递关于request 和客户端的附加信息到服务端,
-- Accept
-- Accept-Charset
-- Accept-Encoding
-- Accept-Language
-- Authorization
-- Expect
-- From
-- Host
-- If-Match
-- If-Modified-Since
-- If-None-Match
-- If-Range
-- If-Unmodified-Since
-- Max-Forwards
-- Proxy-Authorization
-- Range
-- Referer
-- TE
-- User-Agent
*******************************************************************************
Response Header Fields
===============================
response-header fields 允许服务端传递关于response 的、不能放到Status-Line 的附加信息。 这些头给出关于服务端的信息。
,-- Accept-Ranges
-- Age
-- ETag
-- Location
-- Proxy-Authenticate
-- Retry-After
-- Server
-- Vary
-- WWW-Authenticate
******************************************************************************* Entity Header Fields
========================
Entity-header fields 定义关于entity-body 的metainformation(标题字段数据), 如果当前没有body, 则定义被request 确定的资源信息.
一些metainformation 是可选的; 一些是必须的。
-- Allow
-- Content-Encoding
-- Content-Language
-- Content-Length
-- Content-Location
-- Content-MD5
-- Content-Range
-- Content-Type
-- Expires
-- Last-Modified
-- extension-header