HTTP狀態代碼

來源:互聯網
上載者:User

標籤:注意事項   自己   實現   partial   UI   網路   伺服器   串連   cap   

當瀏覽者訪問一個網頁時,瀏覽者的瀏覽器會向網頁所在伺服器發出請求。當瀏覽器接收並顯示網頁前,此網頁所在的伺服器會返回一個包含HTTP狀態代碼的資訊頭(server header)用以響應瀏覽器的請求。

HTTP狀態代碼的英文為HTTP Status Code。

下面是常見的HTTP狀態代碼:

    200 - 請求成功
    301 - 資源(網頁等)被永久轉移到其它URL
    404 - 請求的資源(網頁等)不存在
    500 - 內部伺服器錯誤

HTTP狀態代碼由三個十進位數字組成,第一個十進位數字定義了狀態代碼的類型,後兩個數字沒有分類的作用。HTTP狀態代碼共分為5種類型:
HTTP狀態代碼分類 分類     分類描述
1**     資訊,伺服器收到請求,需要要求者繼續執行操作
2**     成功,操作被成功接收並處理
3**     重新導向,需要進一步的操作以完成請求
4**     用戶端錯誤,請求包含語法錯誤或無法完成請求
5**     伺服器錯誤,伺服器在處理請求的過程中發生了錯誤

 

狀態代碼     狀態代碼英文名稱     中文描述
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協議的版本,無法完成處理

 

Content-Type,內容類型,一般是指網頁中存在的Content-Type,用於定義網路檔案的類型和網頁的編碼,決定瀏覽器將以什麼形式、什麼編碼讀取這個檔案,這就是經常看到一些Asp網頁點擊的結果卻是下載到的一個檔案或一張圖片的原因。

 

HTTP要求標頭提供了關於請求,響應或者其他的發送實體的資訊。

在本章節中我們將具體來介紹HTTP回應標頭資訊。
應答頭     說明
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串連時才需要這個資料。如果你想要利用持久串連的優勢,可以把輸出文檔寫入 ByteArrayOutputStream,完成後查看其大小,然後把該值放入Content-Length頭,最後通過byteArrayStream.writeTo(response.getOutputStream()發送內容。
Content-Type     

表示後面的文檔屬於什麼MIME類型。Servlet預設為text/plain,但通常需要顯式地指定為text/html。由於經常要設定Content-Type,因此HttpServletResponse提供了一個專用的方法setContentType。
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都支援它。
Server     

伺服器名字。Servlet一般不設定這個值,而是由Web伺服器自己設定。
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是基於用戶端/服務端(C/S)的架構模型,通過一個可靠的連結來交換資訊,是一個無狀態的請求/響應協議。

一個HTTP"用戶端"是一個應用程式(Web瀏覽器或其他任何用戶端),通過串連到伺服器達到向伺服器發送一個或多個HTTP的請求的目的。

一個HTTP"伺服器"同樣也是一個應用程式(通常是一個Web服務,如Apache Web伺服器或IIS伺服器等),通過接收用戶端的請求並向用戶端發送HTTP響應資料。

HTTP使用統一資源識別項(Uniform Resource Identifiers, URI)來傳輸資料和建立串連。

一旦建立串連後,資料訊息就通過類似Internet郵件所使用的格式[RFC5322]和多用途Internet郵件擴充(MIME)[RFC2045]來傳送。

用戶端請求訊息

用戶端發送一個HTTP請求到伺服器的請求訊息包括以下格式:請求行(request line)、要求標頭部(header)、空行和請求資料四個部分組成,給出了請求報文的一般格式。

伺服器響應訊息

HTTP響應也由四個部分組成,分別是:狀態行、訊息前序、空行和響應本文。

HTTP 簡介

HTTP協議是Hyper Text Transfer Protocol(超文字傳輸通訊協定 (HTTP))的縮寫,是用於從全球資訊網(WWW:World Wide Web )伺服器傳輸超文本到本地瀏覽器的傳送協議。。

HTTP是一個基於TCP/IP通訊協定來傳遞資料(HTML 檔案, 圖片檔案, 查詢結果等)。
HTTP 工作原理

HTTP協議工作於用戶端-服務端架構為上。瀏覽器作為HTTP用戶端通過URL向HTTP服務端即WEB伺服器發送所有請求。

Web伺服器有:Apache伺服器,IIS伺服器(Internet Information Services)等。

Web伺服器根據接收到的請求後,向用戶端發送響應資訊。

HTTP預設連接埠號碼為80,但是你也可以改為8080或者其他連接埠。

HTTP三點注意事項:

    HTTP是無串連:不需連線的含義是限制每次串連只處理一個請求。伺服器處理完客戶的請求,並收到客戶的應答後,即中斷連線。採用這種方式可以節省傳輸時間。
    HTTP是媒體獨立的:這意味著,只要用戶端和伺服器知道如何處理的資料內容,任何類型的資料都可以通過HTTP發送。用戶端以及伺服器指定使用適合的MIME-type內容類型。
    HTTP是無狀態:HTTP協議是無狀態協議。無狀態是指協議對於交易處理沒有記憶能力。缺少狀態意味著如果後續處理需要前面的資訊,則它必須重傳,這樣可能導致每次串連傳送的資料量增大。另一方面,在伺服器不需要先前資訊時它的應答就較快。

 

來源:http://www.runoob.com/http/http-tutorial.html

HTTP狀態代碼

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.