HTTP協議header頭域

2021-06-16 05:26:02 字數 4435 閱讀 8017

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相同。

請求訊息

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-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服務端響應乙個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協議header頭域

http hypertexttransferprotocol 是超文字傳輸協議的縮寫,它用於傳送www方式的資料,關於http協議的詳細內容請參考rfc2616。http協議採用了請求 響應模型。客戶端向伺服器傳送乙個請求,請求頭包含請求的方法 uri 協議版本 以及包含請求修飾符 客戶資訊和內容的...

HTTP協議header頭域

http hypertexttransferprotocol 是超文字傳輸協議的縮寫,它用於傳送www方式的資料,關於http協議的詳細內 容請參考rfc2616。http協議採用了請求 響應模型。客戶端向伺服器傳送乙個請求,請求頭包含請求的方法 uri 協議版本 以及包含請求修飾 符 客戶資訊和內...

HTTP協議header頭域

http hypertexttransferprotocol 是超文字傳輸協議的縮寫,它用於傳送www方式的資料,關於http協議的詳細內 容請參考rfc2616。http協議採用了請求 響應模型。客戶端向伺服器傳送乙個請求,請求頭包含請求的方法 uri 協議版本 以及包含請求修飾 符 客戶資訊和內...