posts - 297,  comments - 1618,  trackbacks - 0
            本系列下載地址:http://www.aygfsteel.com/Files/amigoxie/http協(xié)議學(xué)習(xí)系列-阿蜜果.rar
            上一篇:基礎(chǔ)概念篇
            下一篇:深入了解篇

                                                  蜜果私塾:http
          協(xié)議學(xué)習(xí)系列
                                           ——協(xié)議詳解篇

          文:阿蜜果

          日期:2009-12-2

          2. 協(xié)議詳解篇

          2.1 HTTP/1.0HTTP/1.1的比較

          RFC 1945定義了HTTP/1.0版本,RFC 2616定義了HTTP/1.1版本。

          筆者在blog上提供了這兩個(gè)RFC中文版的下載地址。

          RFC1945下載地址:

          http://www.aygfsteel.com/Files/amigoxie/RFC1945HTTP)中文版.rar

          RFC2616下載地址:

          http://www.aygfsteel.com/Files/amigoxie/RFC2616HTTP)中文版.rar

          2.1.1建立連接方面

          HTTP/1.0 每次請(qǐng)求都需要建立新的TCP連接,連接不能復(fù)用。HTTP/1.1 新的請(qǐng)求可以在上次請(qǐng)求建立的TCP連接之上發(fā)送,連接可以復(fù)用。優(yōu)點(diǎn)是減少重復(fù)進(jìn)行TCP三次握手的開(kāi)銷,提高效率。

          注意:在同一個(gè)TCP連接中,新的請(qǐng)求需要等上次請(qǐng)求收到響應(yīng)后,才能發(fā)送。

          2.1.2 Host

          HTTP1.1Request消息頭里頭多了一個(gè)Host, HTTP1.0則沒(méi)有這個(gè)域。

          Eg

              GET /pub/WWW/TheProject.html HTTP/1.1
              Host: www.w3.org

              可能HTTP1.0的時(shí)候認(rèn)為,建立TCP連接的時(shí)候已經(jīng)指定了IP地址,這個(gè)IP地址上只有一個(gè)host。

          2.1.3日期時(shí)間戳

          (接收方向)

          無(wú)論是HTTP1.0還是HTTP1.1,都要能解析下面三種date/time stamp

          Sun, 06 Nov 1994 08:49:37 GMT ; RFC 822, updated by RFC 1123
          Sunday, 06-Nov-94 08:49:37 GMT ; RFC 850, obsoleted by RFC 1036
          Sun Nov 6 08:49:37 1994       ; ANSI C's asctime() format

                 (發(fā)送方向)

          HTTP1.0要求不能生成第三種asctime格式的date/time stamp

          HTTP1.1則要求只生成RFC 1123(第一種)格式的date/time stamp。

          2.1.4狀態(tài)響應(yīng)碼

          狀態(tài)響應(yīng)碼100 (Continue) 狀態(tài)代碼的使用,允許客戶端在發(fā)request消息body之前先用request header試探一下server,看server要不要接收request body,再?zèng)Q定要不要發(fā)request body。

          客戶端在Request頭部中包含

          Expect: 100-continue

                 Server看到之后呢如果回100 (Continue) 這個(gè)狀態(tài)代碼,客戶端就繼續(xù)發(fā)request body。這個(gè)是HTTP1.1才有的。

          另外在HTTP/1.1中還增加了101203、205等等性狀態(tài)響應(yīng)碼

          2.1.5請(qǐng)求方式

          HTTP1.1增加了OPTIONS, PUT, DELETE, TRACE, CONNECT這些Request方法.

                 Method         = "OPTIONS"                ; Section 9.2

                                | "GET"                    ; Section 9.3

                                | "HEAD"                   ; Section 9.4

                                | "POST"                   ; Section 9.5

                                | "PUT"                    ; Section 9.6

                                | "DELETE"                 ; Section 9.7

                                | "TRACE"                  ; Section 9.8

                                | "CONNECT"                ; Section 9.9

                                | extension-method

                 extension-method = token

          2.2 HTTP請(qǐng)求消息

          2.2.1請(qǐng)求消息格式

          請(qǐng)求消息格式如下所示:

          請(qǐng)求行

          通用信息頭|請(qǐng)求頭|實(shí)體頭

          CRLF(回車換行)

          實(shí)體內(nèi)容

          其中“請(qǐng)求行”為:請(qǐng)求行 = 方法 [空格] 請(qǐng)求URI [空格] 版本號(hào) [回車換行]

          請(qǐng)求行實(shí)例:

          Eg1

          GET /index.html HTTP/1.1

                 Eg2

          POST http://192.168.2.217:8080/index.jsp HTTP/1.1

          HTTP請(qǐng)求消息實(shí)例:

          GET /hello.htm HTTP/1.1
          Accept: */*
          Accept-Language: zh-cn
          Accept-Encoding: gzip, deflate
          If-Modified-Since: Wed, 17 Oct 2007 02:15:55 GMT
          If-None-Match: W/"158-1192587355000"
          User-Agent: Mozilla/4.0 (compatible; MSIE 6.0; Windows NT 5.1; SV1)
          Host: 192.168.2.162:8080
          Connection: Keep-Alive


          2.2.2請(qǐng)求方法

                 HTTP的請(qǐng)求方法包括如下幾種:

          q      GET

          q      POST

          q      HEAD

          q      PUT

          q      DELETE

          q      OPTIONS

          q      TRACE

          q      CONNECT

          2.3 HTTP響應(yīng)消息

          2.3.1響應(yīng)消息格式

          HTTP響應(yīng)消息的格式如下所示:

          狀態(tài)行

          通用信息頭|響應(yīng)頭|實(shí)體頭

          CRLF

          實(shí)體內(nèi)容

          其中:狀態(tài)行 = 版本號(hào) [空格] 狀態(tài)碼 [空格] 原因 [回車換行]

          狀態(tài)行舉例:

          Eg1

          HTTP/1.0 200 OK 

                Eg2

          HTTP/1.1 400 Bad Request

               HTTP響應(yīng)消息實(shí)例如下所示:

          HTTP/1.1 200 OK
          ETag: W/"158-1192590101000"
          Last-Modified: Wed, 17 Oct 2007 03:01:41 GMT
          Content-Type: text/html
          Content-Length: 158
          Date: Wed, 17 Oct 2007 03:01:59 GMT
          Server: Apache-Coyote/1.1

          2.3.2 http的狀態(tài)響應(yīng)碼

          2.3.2.1  1**:請(qǐng)求收到,繼續(xù)處理

          100——客戶必須繼續(xù)發(fā)出請(qǐng)求

          101——客戶要求服務(wù)器根據(jù)請(qǐng)求轉(zhuǎn)換HTTP協(xié)議版本

          2.3.2.2  2**操作成功收到分析、接受

          200——交易成功
          201——提示知道新文件的URL

          202——接受和處理、但處理未完成

          203——返回信息不確定或不完整

          204——請(qǐng)求收到,但返回信息為空

          205——服務(wù)器完成了請(qǐng)求,用戶代理必須復(fù)位當(dāng)前已經(jīng)瀏覽過(guò)的文件

          206——服務(wù)器已經(jīng)完成了部分用戶的GET請(qǐng)求

          2.3.2.3  3**:完成此請(qǐng)求必須進(jìn)一步處理

          300——請(qǐng)求的資源可在多處得到

          301——刪除請(qǐng)求數(shù)據(jù)

          302——在其他地址發(fā)現(xiàn)了請(qǐng)求數(shù)據(jù)

          303——建議客戶訪問(wèn)其他URL或訪問(wèn)方式

          304——客戶端已經(jīng)執(zhí)行了GET,但文件未變化

          305——請(qǐng)求的資源必須從服務(wù)器指定的地址得到

          306——前一版本HTTP中使用的代碼,現(xiàn)行版本中不再使用

          307——申明請(qǐng)求的資源臨時(shí)性刪除

          2.3.2.4  4**:請(qǐng)求包含一個(gè)錯(cuò)誤語(yǔ)法或不能完成

          400——錯(cuò)誤請(qǐng)求,如語(yǔ)法錯(cuò)誤

          401——未授權(quán)

          HTTP 401.1 - 未授權(quán):登錄失敗

            HTTP 401.2 - 未授權(quán):服務(wù)器配置問(wèn)題導(dǎo)致登錄失敗

            HTTP 401.3 - ACL 禁止訪問(wèn)資源

            HTTP 401.4 - 未授權(quán):授權(quán)被篩選器拒絕

          HTTP 401.5 - 未授權(quán):ISAPI CGI 授權(quán)失敗

          402——保留有效ChargeTo頭響應(yīng)

          403——禁止訪問(wèn)

          HTTP 403.1 禁止訪問(wèn):禁止可執(zhí)行訪問(wèn)

            HTTP 403.2 - 禁止訪問(wèn):禁止讀訪問(wèn)

            HTTP 403.3 - 禁止訪問(wèn):禁止寫訪問(wèn)

            HTTP 403.4 - 禁止訪問(wèn):要求 SSL

            HTTP 403.5 - 禁止訪問(wèn):要求 SSL 128

            HTTP 403.6 - 禁止訪問(wèn):IP 地址被拒絕

            HTTP 403.7 - 禁止訪問(wèn):要求客戶證書(shū)

            HTTP 403.8 - 禁止訪問(wèn):禁止站點(diǎn)訪問(wèn)

            HTTP 403.9 - 禁止訪問(wèn):連接的用戶過(guò)多

            HTTP 403.10 - 禁止訪問(wèn):配置無(wú)效

            HTTP 403.11 - 禁止訪問(wèn):密碼更改

            HTTP 403.12 - 禁止訪問(wèn):映射器拒絕訪問(wèn)

            HTTP 403.13 - 禁止訪問(wèn):客戶證書(shū)已被吊銷

            HTTP 403.15 - 禁止訪問(wèn):客戶訪問(wèn)許可過(guò)多

            HTTP 403.16 - 禁止訪問(wèn):客戶證書(shū)不可信或者無(wú)效

          HTTP 403.17 - 禁止訪問(wèn):客戶證書(shū)已經(jīng)到期或者尚未生效

          404——沒(méi)有發(fā)現(xiàn)文件、查詢或URl

          405——用戶在Request-Line字段定義的方法不允許

          406——根據(jù)用戶發(fā)送的Accept拖,請(qǐng)求資源不可訪問(wèn)

          407——類似401,用戶必須首先在代理服務(wù)器上得到授權(quán)

          408——客戶端沒(méi)有在用戶指定的餓時(shí)間內(nèi)完成請(qǐng)求

          409——對(duì)當(dāng)前資源狀態(tài),請(qǐng)求不能完成

          410——服務(wù)器上不再有此資源且無(wú)進(jìn)一步的參考地址

          411——服務(wù)器拒絕用戶定義的Content-Length屬性請(qǐng)求

          412——一個(gè)或多個(gè)請(qǐng)求頭字段在當(dāng)前請(qǐng)求中錯(cuò)誤

          413——請(qǐng)求的資源大于服務(wù)器允許的大小

          414——請(qǐng)求的資源URL長(zhǎng)于服務(wù)器允許的長(zhǎng)度

          415——請(qǐng)求資源不支持請(qǐng)求項(xiàng)目格式

          416——請(qǐng)求中包含Range請(qǐng)求頭字段,在當(dāng)前請(qǐng)求資源范圍內(nèi)沒(méi)有range指示值,請(qǐng)求也不包含If-Range請(qǐng)求頭字段

          417——服務(wù)器不滿足請(qǐng)求Expect頭字段指定的期望值,如果是代理服務(wù)器,可能是下一級(jí)服務(wù)器不能滿足請(qǐng)求長(zhǎng)。

          2.3.2.5  5**:服務(wù)器執(zhí)行一個(gè)完全有效請(qǐng)求失敗

            HTTP 500 - 內(nèi)部服務(wù)器錯(cuò)誤

            HTTP 500.100 - 內(nèi)部服務(wù)器錯(cuò)誤 - ASP 錯(cuò)誤

            HTTP 500-11 服務(wù)器關(guān)閉

            HTTP 500-12 應(yīng)用程序重新啟動(dòng)

            HTTP 500-13 - 服務(wù)器太忙

            HTTP 500-14 - 應(yīng)用程序無(wú)效

            HTTP 500-15 - 不允許請(qǐng)求 global.asa

            Error 501 - 未實(shí)現(xiàn)

          HTTP 502 - 網(wǎng)關(guān)錯(cuò)誤

          2.4 使用telnet進(jìn)行http測(cè)試

                 Windows下,可使用命令窗口進(jìn)行http簡(jiǎn)單測(cè)試。

                 輸入cmd進(jìn)入命令窗口,在命令行鍵入如下命令后按回車:

          telnet www.baidu.com 80

                 而后在窗口中按下Ctrl+]后按回車可讓返回結(jié)果回顯。

          接著開(kāi)始發(fā)請(qǐng)求消息,例如發(fā)送如下請(qǐng)求消息請(qǐng)求baidu的首頁(yè)消息,使用的HTTP協(xié)議為HTTP/1.1

          GET /index.html HTTP/1.1

             注意:copy如上的消息到命令窗口后需要按兩個(gè)回車換行才能得到響應(yīng)的消息,第一個(gè)回車換行是在命令后鍵入回車換行,是HTTP協(xié)議要求的。第二個(gè)是確認(rèn)輸入,發(fā)送請(qǐng)求。

          可看到返回了200 OK的消息,如下圖所示:

                 可看到,當(dāng)采用HTTP/1.1時(shí),連接不是在請(qǐng)求結(jié)束后就斷開(kāi)的。若采用HTTP1.0,在命令窗口鍵入:

          GET /index.html HTTP/1.0

                此時(shí)可以看到請(qǐng)求結(jié)束之后馬上斷開(kāi)。

                 讀者還可以嘗試在使用GETPOST等時(shí),帶上頭域信息,例如鍵入如下信息:

          GET /index.html HTTP/1.1
          connection: close
          Host: www.baidu.com

          2.5 常用的請(qǐng)求方式

                 常用的請(qǐng)求方式是GETPOST.

          l         GET方式:是以實(shí)體的方式得到由請(qǐng)求URI所指定資源的信息,如果請(qǐng)求URI只是一個(gè)數(shù)據(jù)產(chǎn)生過(guò)程,那么最終要在響應(yīng)實(shí)體中返回的是處理過(guò)程的結(jié)果所指向的資源,而不是處理過(guò)程的描述。

          l         POST方式:用來(lái)向目的服務(wù)器發(fā)出請(qǐng)求,要求它接受被附在請(qǐng)求后的實(shí)體,并把它當(dāng)作請(qǐng)求隊(duì)列中請(qǐng)求URI所指定資源的附加新子項(xiàng),Post被設(shè)計(jì)成用統(tǒng)一的方法實(shí)現(xiàn)下列功能:

          1:對(duì)現(xiàn)有資源的解釋;

          2:向電子公告欄、新聞組、郵件列表或類似討論組發(fā)信息;

          3:提交數(shù)據(jù)塊;

          4:通過(guò)附加操作來(lái)擴(kuò)展數(shù)據(jù)庫(kù) 。

          從上面描述可以看出,Get是向服務(wù)器發(fā)索取數(shù)據(jù)的一種請(qǐng)求;而Post是向服務(wù)器提交數(shù)據(jù)的一種請(qǐng)求,要提交的數(shù)據(jù)位于信息頭后面的實(shí)體中。

          GETPOST方法有以下區(qū)別:

          1   在客戶端,Get方式在通過(guò)URL提交數(shù)據(jù),數(shù)據(jù)在URL中可以看到;POST方式,數(shù)據(jù)放置在HTML HEADER內(nèi)提交。

          2   GET方式提交的數(shù)據(jù)最多只能有1024字節(jié),而POST則沒(méi)有此限制。

          3   安全性問(wèn)題。正如在(1)中提到,使用 Get 的時(shí)候,參數(shù)會(huì)顯示在地址欄上,而 Post 不會(huì)。所以,如果這些數(shù)據(jù)是中文數(shù)據(jù)而且是非敏感數(shù)據(jù),那么使用 get;如果用戶輸入的數(shù)據(jù)不是中文字符而且包含敏感數(shù)據(jù),那么還是使用 post為好。

          4   安全的和冪等的。所謂安全的意味著該操作用于獲取信息而非修改信息。冪等的意味著對(duì)同一 URL 的多個(gè)請(qǐng)求應(yīng)該返回同樣的結(jié)果。完整的定義并不像看起來(lái)那樣嚴(yán)格。換句話說(shuō),GET 請(qǐng)求一般不應(yīng)產(chǎn)生副作用。從根本上講,其目標(biāo)是當(dāng)用戶打開(kāi)一個(gè)鏈接時(shí),她可以確信從自身的角度來(lái)看沒(méi)有改變資源。比如,新聞?wù)军c(diǎn)的頭版不斷更新。雖然第二次請(qǐng)求會(huì)返回不同的一批新聞,該操作仍然被認(rèn)為是安全的和冪等的,因?yàn)樗偸欠祷禺?dāng)前的新聞。反之亦然。POST 請(qǐng)求就不那么輕松了。POST 表示可能改變服務(wù)器上的資源的請(qǐng)求。仍然以新聞?wù)军c(diǎn)為例,讀者對(duì)文章的注解應(yīng)該通過(guò) POST 請(qǐng)求實(shí)現(xiàn),因?yàn)樵谧⒔馓峤恢笳军c(diǎn)已經(jīng)不同了(比方說(shuō)文章下面出現(xiàn)一條注解)。
           

          2.6 請(qǐng)求頭

          HTTP最常見(jiàn)的請(qǐng)求頭如下:

          l         Accept:瀏覽器可接受的MIME類型;

          l         Accept-Charset:瀏覽器可接受的字符集;

          l         Accept-Encoding:瀏覽器能夠進(jìn)行解碼的數(shù)據(jù)編碼方式,比如gzip。Servlet能夠向支持gzip的瀏覽器返回經(jīng)gzip編碼的HTML頁(yè)面。許多情形下這可以減少510倍的下載時(shí)間;

          l         Accept-Language:瀏覽器所希望的語(yǔ)言種類,當(dāng)服務(wù)器能夠提供一種以上的語(yǔ)言版本時(shí)要用到;

          l         Authorization:授權(quán)信息,通常出現(xiàn)在對(duì)服務(wù)器發(fā)送的WWW-Authenticate頭的應(yīng)答中;

          l         Connection:表示是否需要持久連接。如果Servlet看到這里的值為“Keep-Alive”,或者看到請(qǐng)求使用的是HTTP 1.1HTTP 1.1默認(rèn)進(jìn)行持久連接),它就可以利用持久連接的優(yōu)點(diǎn),當(dāng)頁(yè)面包含多個(gè)元素時(shí)(例如Applet,圖片),顯著地減少下載所需要的時(shí)間。要實(shí)現(xiàn)這一點(diǎn),Servlet需要在應(yīng)答中發(fā)送一個(gè)Content-Length頭,最簡(jiǎn)單的實(shí)現(xiàn)方法是:先把內(nèi)容寫入ByteArrayOutputStream,然后在正式寫出內(nèi)容之前計(jì)算它的大??;

          l         Content-Length:表示請(qǐng)求消息正文的長(zhǎng)度;

          l         Cookie:這是最重要的請(qǐng)求頭信息之一;

          l         From:請(qǐng)求發(fā)送者的email地址,由一些特殊的Web客戶程序使用,瀏覽器不會(huì)用到它;

          l         Host:初始URL中的主機(jī)和端口;

          l         If-Modified-Since:只有當(dāng)所請(qǐng)求的內(nèi)容在指定的日期之后又經(jīng)過(guò)修改才返回它,否則返回304“Not Modified”應(yīng)答;

          l         Pragma:指定“no-cache”值表示服務(wù)器必須返回一個(gè)刷新后的文檔,即使它是代理服務(wù)器而且已經(jīng)有了頁(yè)面的本地拷貝;

          l         Referer:包含一個(gè)URL,用戶從該URL代表的頁(yè)面出發(fā)訪問(wèn)當(dāng)前請(qǐng)求的頁(yè)面。

          l         User-Agent:瀏覽器類型,如果Servlet返回的內(nèi)容與瀏覽器類型有關(guān)則該值非常有用;

          l         UA-PixelsUA-Color,UA-OS,UA-CPU:由某些版本的IE瀏覽器所發(fā)送的非標(biāo)準(zhǔn)的請(qǐng)求頭,表示屏幕大小、顏色深度、操作系統(tǒng)和CPU類型。

          2.7 響應(yīng)頭

          HTTP最常見(jiàn)的響應(yīng)頭如下所示:

          l         Allow:服務(wù)器支持哪些請(qǐng)求方法(如GET、POST等);

          l         Content-Encoding:文檔的編碼(Encode)方法。只有在解碼之后才可以得到Content-Type頭指定的內(nèi)容類型。利用gzip壓縮文檔能夠顯著地減少HTML文檔的下載時(shí)間。JavaGZIPOutputStream可以很方便地進(jìn)行gzip壓縮,但只有Unix上的NetscapeWindows上的IE 4、IE 5才支持它。因此,Servlet應(yīng)該通過(guò)查看Accept-Encoding頭(即request.getHeader("Accept-Encoding"))檢查瀏覽器是否支持gzip,為支持gzip的瀏覽器返回經(jīng)gzip壓縮的HTML頁(yè)面,為其他瀏覽器返回普通頁(yè)面;

          l         Content-Length:表示內(nèi)容長(zhǎng)度。只有當(dāng)瀏覽器使用持久HTTP連接時(shí)才需要這個(gè)數(shù)據(jù)。如果你想要利用持久連接的優(yōu)勢(shì),可以把輸出文檔寫入ByteArrayOutputStram,完成后查看其大小,然后把該值放入Content-Length頭,最后通過(guò)byteArrayStream.writeTo(response.getOutputStream()發(fā)送內(nèi)容;

          l         Content-Type 表示后面的文檔屬于什么MIME類型。Servlet默認(rèn)為text/plain,但通常需要顯式地指定為text/html。由于經(jīng)常要設(shè)置Content-Type,因此HttpServletResponse提供了一個(gè)專用的方法setContentTyep 可在web.xml文件中配置擴(kuò)展名和MIME類型的對(duì)應(yīng)關(guān)系;

          l         Date:當(dāng)前的GMT時(shí)間。你可以用setDateHeader來(lái)設(shè)置這個(gè)頭以避免轉(zhuǎn)換時(shí)間格式的麻煩;

          l         Expires:指明應(yīng)該在什么時(shí)候認(rèn)為文檔已經(jīng)過(guò)期,從而不再緩存它。

          l         Last-Modified:文檔的最后改動(dòng)時(shí)間??蛻艨梢酝ㄟ^(guò)If-Modified-Since請(qǐng)求頭提供一個(gè)日期,該請(qǐng)求將被視為一個(gè)條件GET,只有改動(dòng)時(shí)間遲于指定時(shí)間的文檔才會(huì)返回,否則返回一個(gè)304Not Modified)狀態(tài)。Last-Modified也可用setDateHeader方法來(lái)設(shè)置;

          l         Location:表示客戶應(yīng)當(dāng)?shù)侥睦锶ヌ崛∥臋n。Location通常不是直接設(shè)置的,而是通過(guò)HttpServletResponsesendRedirect方法,該方法同時(shí)設(shè)置狀態(tài)代碼為302;

          l         Refresh:表示瀏覽器應(yīng)該在多少時(shí)間之后刷新文檔,以秒計(jì)。除了刷新當(dāng)前文檔之外,你還可以通過(guò)setHeader("Refresh", "5; URL=http://host/path")讓瀏覽器讀取指定的頁(yè)面。注意這種功能通常是通過(guò)設(shè)置HTML頁(yè)面HEAD區(qū)的<META HTTP-EQUIV="Refresh" CONTENT="5;URL=http://host/path">實(shí)現(xiàn),這是因?yàn)?,自?dòng)刷新或重定向?qū)τ谀切┎荒苁褂?/span>CGIServletHTML編寫者十分重要。但是,對(duì)于Servlet來(lái)說(shuō),直接設(shè)置Refresh頭更加方便。注意Refresh的意義是“N秒之后刷新本頁(yè)面或訪問(wèn)指定頁(yè)面,而不是每隔N秒刷新本頁(yè)面或訪問(wèn)指定頁(yè)面。因此,連續(xù)刷新要求每次都發(fā)送一個(gè)Refresh頭,而發(fā)送204狀態(tài)代碼則可以阻止瀏覽器繼續(xù)刷新,不管是使用Refresh頭還是<META HTTP-EQUIV="Refresh" ...>。注意Refresh頭不屬于HTTP 1.1正式規(guī)范的一部分,而是一個(gè)擴(kuò)展,但NetscapeIE都支持它。

          2.8實(shí)體頭

          實(shí)體頭用坐實(shí)體內(nèi)容的元信息,描述了實(shí)體內(nèi)容的屬性,包括實(shí)體信息類型,長(zhǎng)度,壓縮方法,最后一次修改時(shí)間,數(shù)據(jù)有效性等。

          l         AllowGET,POST

          l         Content-Encoding:文檔的編碼(Encode)方法,例如:gzip,見(jiàn)2.5 響應(yīng)頭”;

          l         Content-Language:內(nèi)容的語(yǔ)言類型,例如:zh-cn;

          l         Content-Length:表示內(nèi)容長(zhǎng)度,eg80,可參考“2.5響應(yīng)頭”;

          l         Content-Location:表示客戶應(yīng)當(dāng)?shù)侥睦锶ヌ崛∥臋n,例如:http://www.dfdf.org/dfdf.html,可參考“2.5響應(yīng)頭”;

          l         Content-MD5MD5 實(shí)體的一種MD5摘要,用作校驗(yàn)和。發(fā)送方和接受方都計(jì)算MD5摘要,接受方將其計(jì)算的值與此頭標(biāo)中傳遞的值進(jìn)行比較。Eg1Content-MD5: <base64 of 128 MD5 digest>。Eg2dfdfdfdfdfdfdff==;

          l         Content-Range:隨部分實(shí)體一同發(fā)送;標(biāo)明被插入字節(jié)的低位與高位字節(jié)偏移,也標(biāo)明此實(shí)體的總長(zhǎng)度。Eg1Content-Range: 1001-2000/5000eg2bytes 2543-4532/7898

          l         Content-Type:標(biāo)明發(fā)送或者接收的實(shí)體的MIME類型。Egtext/html; charset=GB2312       主類型/子類型;

          l         Expires:為0證明不緩存;

          l         Last-ModifiedWEB 服務(wù)器認(rèn)為對(duì)象的最后修改時(shí)間,比如文件的最后修改時(shí)間,動(dòng)態(tài)頁(yè)面的最后產(chǎn)生時(shí)間等等。例如:Last-ModifiedTue, 06 May 2008 02:42:43 GMT.

          2.8擴(kuò)展頭

          HTTP消息中,也可以使用一些再HTTP1.1正式規(guī)范里沒(méi)有定義的頭字段,這些頭字段統(tǒng)稱為自定義的HTTP頭或者擴(kuò)展頭,他們通常被當(dāng)作是一種實(shí)體頭處理。

          現(xiàn)在流行的瀏覽器實(shí)際上都支持Cookie,Set-Cookie,RefreshContent-Disposition等幾個(gè)常用的擴(kuò)展頭字段。

          l         Refresh1;url=http://www.dfdf.org  //過(guò)1秒跳轉(zhuǎn)到指定位置;

          l         Content-Disposition:頭字段,可參考“2.5響應(yīng)頭”;

          l         Content-TypeWEB 服務(wù)器告訴瀏覽器自己響應(yīng)的對(duì)象的類型。

          eg1Content-Typeapplication/xml

          eg2applicaiton/octet-stream;

          Content-Dispositionattachment; filename=aaa.zip
            附錄:參考資料

          HTTP1.1HTTP1.0的區(qū)別》:

          http://blog.csdn.net/yanghehong/archive/2009/05/28/4222594.aspx

          HTTP請(qǐng)求(GETPOST區(qū)別)和響應(yīng)》:

          http://www.aygfsteel.com/honeybee/articles/164008.html
           

          HTTP請(qǐng)求頭概述_百度知道》:

          http://zhidao.baidu.com/question/32517427.html

          《實(shí)體頭和擴(kuò)展頭》:

          http://www.cnblogs.com/tongzhiyong/archive/2008/03/16/1108776.html

          posted on 2009-12-02 14:46 阿蜜果 閱讀(23673) 評(píng)論(5)  編輯  收藏 所屬分類: Web協(xié)議


          FeedBack:
          # re: http協(xié)議學(xué)習(xí)和總結(jié)系列——協(xié)議詳解篇
          2010-07-14 11:15 | Aidan
          支持一個(gè),不錯(cuò)不錯(cuò)。  回復(fù)  更多評(píng)論
            
          # re: 蜜果私塾:http協(xié)議學(xué)習(xí)和總結(jié)系列——協(xié)議詳解篇[未登錄](méi)
          2011-11-01 22:03 | jim
          你好,我在用c寫一個(gè)簡(jiǎn)單瀏覽器,看到了你這篇文章,學(xué)習(xí)了一些,我在編程的時(shí)候遇到了個(gè)問(wèn)題,希望你能幫忙解決下,在請(qǐng)求的時(shí)候,無(wú)論是簡(jiǎn)單的就一句:GET /index.html HTTP/1.1還是請(qǐng)求頭加上各種域頭,給服務(wù)器端發(fā)送了后,得到的回復(fù)始終只有一個(gè)實(shí)體頭,沒(méi)有實(shí)體,也就是沒(méi)有那個(gè)html文件,read返回的字?jǐn)?shù)也是那個(gè)實(shí)體頭,搞了半天都不知道是什么原因,網(wǎng)上也找不到答案,希望你能幫我解決下,非常感謝?。?!  回復(fù)  更多評(píng)論
            
          # re: 蜜果私塾:http協(xié)議學(xué)習(xí)和總結(jié)系列——協(xié)議詳解篇[未登錄](méi)
          2011-11-01 22:25 | jim
          剛才我稍微改了下,這下成功了,原因是第一次read的時(shí)候,實(shí)體還沒(méi)有到(應(yīng)該是這樣的,在read的時(shí)候我要求的字節(jié)數(shù)足夠大,如果到了應(yīng)該裝得下的,后來(lái)我又改了下,在讀之前睡了一段時(shí)間,然后就讀到了),然后我再調(diào)用了下read,終于讀到了實(shí)體??!
          把我的教訓(xùn)留在這里吧,警示后人............  回復(fù)  更多評(píng)論
            
          # re: 蜜果私塾:http協(xié)議學(xué)習(xí)和總結(jié)系列——協(xié)議詳解篇[未登錄](méi)
          2011-11-01 22:26 | jim
          我剛才改了下,成功了,原來(lái)在第一次read的時(shí)候,實(shí)體還沒(méi)有到(應(yīng)該是這樣的,在read的時(shí)候我要求的字節(jié)數(shù)足夠大,如果到了應(yīng)該裝得下的,后來(lái)我又改了下,在讀之前睡了一段時(shí)間,然后就讀到了),然后我再調(diào)用了下read,終于讀到了實(shí)體??!
          把我的教訓(xùn)留在這里吧,警示后人............  回復(fù)  更多評(píng)論
            
          # re: 蜜果私塾:http協(xié)議學(xué)習(xí)和總結(jié)系列——協(xié)議詳解篇[未登錄](méi)
          2013-07-22 16:45 | 隨風(fēng)逝
          好高深,學(xué)習(xí)了  回復(fù)  更多評(píng)論
            
          <2009年12月>
          293012345
          6789101112
          13141516171819
          20212223242526
          272829303112
          3456789

                生活將我們磨圓,是為了讓我們滾得更遠(yuǎn)——“圓”來(lái)如此。
                我的作品:
                玩轉(zhuǎn)Axure RP  (2015年12月出版)
                

                Power Designer系統(tǒng)分析與建模實(shí)戰(zhàn)  (2015年7月出版)
                
               Struts2+Hibernate3+Spring2   (2010年5月出版)
               

          留言簿(263)

          隨筆分類

          隨筆檔案

          文章分類

          相冊(cè)

          關(guān)注blog

          積分與排名

          • 積分 - 2296321
          • 排名 - 3

          最新評(píng)論

          閱讀排行榜

          評(píng)論排行榜

          主站蜘蛛池模板: 大宁县| 龙井市| 玉屏| 襄城县| 阿尔山市| 和龙市| 明水县| 永登县| 古蔺县| 曲靖市| 高淳县| 宜黄县| 绵竹市| 曲松县| 康马县| 襄樊市| 许昌县| 芜湖市| 连平县| 鞍山市| 甘肃省| 溆浦县| 北碚区| 本溪市| 连平县| 女性| 淮阳县| 敖汉旗| 望城县| 鸡东县| 班玛县| 章丘市| 炎陵县| 万源市| 林西县| 龙江县| 和龙市| 辽宁省| 安乡县| 巩义市| 河南省|