1. 程式人生 > >關於HTTP協議的訊息結構和狀態碼

關於HTTP協議的訊息結構和狀態碼

訊息結構

HTTP使用統一資源識別符號(Uniform Resource Identifiers, URI)來傳輸資料建立連線。一旦建立連線後,資料訊息就通過類似Internet郵件所使用的格式[RFC5322]和多用途Internet郵件擴充套件(MIME)[RFC2045]來傳送。

客戶端請求訊息:請求行、請求頭部、空行和請求資料。

GET /hello.txt HTTP/1.1
User-Agent: curl/7.16.3 libcurl/7.16.3          
OpenSSL/0.9.7l zlib/1.2.3          
Host: www.example.com Accept-Language: en, mi         

服務端響應訊息:狀態行、訊息報頭、空行和響應正文。

HTTP/1.1 200 OK         
Date: Mon, 27 Jul 2009 12:28:53 GMT         
Server: Apache         
Last-Modified: Wed, 22 Jul 2009 19:15:56 GMT         
ETag: "34aa387-d-1568eb00"         
Accept-Ranges: bytes         
Content-Length: 51         
Vary: Accept-Encoding         
Content-Type
: text/plain

請求方法

GET 請求指定的頁面資訊,並返回實體主體。 HEAD 類似於get請求,只不過返回的響應中沒有具體的內容,用於獲取報頭 POST 向指定資源提交資料進行處理請求(例如提交表單或者上傳檔案)。資料被包含在請求體中。POST請求可能會導致新的資源的建立和/或已有資源的修改。 PUT 從客戶端向伺服器傳送的資料取代指定的文件的內容。 DELETE 請求伺服器刪除指定的頁面。 CONNECT HTTP/1.1協議中預留給能夠將連線改為管道方式的代理伺服器。 OPTIONS 允許客戶端檢視伺服器的效能。 TRACE 回顯伺服器收到的請求,主要用於測試或診斷。

狀態碼

HTTP狀態碼分類

1** 資訊,伺服器收到請求,需要請求者繼續執行操作 2** 成功,操作被成功接收並處理 3** 重定向,需要進一步的操作以完成請求 4** 客戶端錯誤,請求包含語法錯誤或無法完成請求 5** 伺服器錯誤,伺服器在處理請求的過程中發生了錯

HTTP狀態碼列表

100 Continue 繼續。客戶端應繼續其請求 101 Switching Protocols 切換協議。伺服器根據客戶端的請求切換協議。只能切換到更高階的協議,例如,切換到HTTP的新版本協議 200 OK 請求成功。一般用於GET與POST請求 201 Created 已建立。成功請求並建立了新的資源 202 Accepted 已接受。已經接受請求,但未處理完成 203 Non-Authoritative Information 非授權資訊。請求成功。但返回的meta資訊不在原始的伺服器,而是一個副本 204 No Content 無內容。伺服器成功處理,但未返回內容。在未更新網頁的情況下,可確保瀏覽器繼續顯示當前文件 205 Reset Content 重置內容。伺服器處理成功,使用者終端(例如:瀏覽器)應重置文件檢視。可通過此返回碼清除瀏覽器的表單域 206 Partial Content 部分內容。伺服器成功處理了部分GET請求 300 Multiple Choices 多種選擇。請求的資源可包括多個位置,相應可返回一個資源特徵與地址的列表用於使用者終端(例如:瀏覽器)選擇 301 Moved Permanently 永久移動。請求的資源已被永久的移動到新URI,返回資訊會包括新的URI,瀏覽器會自動定向到新URI。今後任何新的請求都應使用新的URI代替 302 Found 臨時移動。與301類似。但資源只是臨時被移動。客戶端應繼續使用原有URI 303 See Other 檢視其它地址。與301類似。使用GET和POST請求檢視 304 Not Modified 未修改。所請求的資源未修改,伺服器返回此狀態碼時,不會返回任何資源。客戶端通常會快取訪問過的資源,通過提供一個頭資訊指出客戶端希望只返回在指定日期之後修改的資源 305 Use Proxy 使用代理。所請求的資源必須通過代理訪問 306 Unused 已經被廢棄的HTTP狀態碼 307 Temporary Redirect 臨時重定向。與302類似。使用GET請求重定向 400 Bad Request 客戶端請求的語法錯誤,伺服器無法理解 401 Unauthorized 請求要求使用者的身份認證 402 Payment Required 保留,將來使用 403 Forbidden 伺服器理解請求客戶端的請求,但是拒絕執行此請求 404 Not Found 伺服器無法根據客戶端的請求找到資源(網頁)。通過此程式碼,網站設計人員可設定”您所請求的資源無法找到”的個性頁面 405 Method Not Allowed 客戶端請求中的方法被禁止 406 Not Acceptable 伺服器無法根據客戶端請求的內容特性完成請求 407 Proxy Authentication Required 請求要求代理的身份認證,與401類似,但請求者應當使用代理進行授權 408 Request Time-out 伺服器等待客戶端傳送的請求時間過長,超時 409 Conflict 伺服器完成客戶端的PUT請求是可能返回此程式碼,伺服器處理請求時發生了衝突 410 Gone 客戶端請求的資源已經不存在。410不同於404,如果資源以前有現在被永久刪除了可使用410程式碼,網站設計人員可通過301程式碼指定資源的新位置 411 Length Required 伺服器無法處理客戶端傳送的不帶Content-Length的請求資訊 412 Precondition Failed 客戶端請求資訊的先決條件錯誤 413 Request Entity Too Large 由於請求的實體過大,伺服器無法處理,因此拒絕請求。為防止客戶端的連續請求,伺服器可能會關閉連線。如果只是伺服器暫時無法處理,則會包含一個Retry-After的響應資訊 414 Request-URI Too Large 請求的URI過長(URI通常為網址),伺服器無法處理 415 Unsupported Media Type 伺服器無法處理請求附帶的媒體格式 416 Requested range not satisfiable 客戶端請求的範圍無效 417 Expectation Failed 伺服器無法滿足Expect的請求頭資訊 500 Internal Server Error 伺服器內部錯誤,無法完成請求 501 Not Implemented 伺服器不支援請求的功能,無法完成請求 502 Bad Gateway 充當閘道器或代理的伺服器,從遠端伺服器接收到了一個無效的請求 503 Service Unavailable 由於超載或系統維護,伺服器暫時的無法處理客戶端的請求。延時的長度可包含在伺服器的Retry-After頭資訊中 504 Gateway Time-out 充當閘道器或代理的伺服器,未及時從遠端伺服器獲取請求 505 HTTP Version not supported 伺服器不支援請求的HTTP協議的版本,無法完成處理