HTTP 303

HTTP回應狀態碼

HTTP 303 See Other ,自 RFC 2616(HTTP 1.1)起,用於在收到HTTP POST請求之後,進行URL重新導向的操作。[1]

引入

雖然RFC 1945RFC 2068規範不允許客戶端在重新導向時改變請求的方法,但是很多現存的瀏覽器在收到302響應時,直接使用GET方式訪問在Location中規定的URI,而無視原先請求的方法。[2]因此狀態碼303被添加了進來,用以明確伺服器期待客戶端進行何種反應。[3]

定義

根據RFC 2616定義:

  • 此方法主要用於允許在收到POST方法後響應時,將用戶重新導向到所選資源。
  • 如果一個客戶端有連結編輯能力,其應當把所有的參照連結重新導向到新的URL上。
  • 重新導向到新地址時,客戶端必須使用GET方法請求新地址。
  • 客戶端收到的新的URI,不是原始請求資源的替代參照。
  • 該響應碼不應被客戶端快取,惟重新導向後的頁面不受此限。
  • 除非請求方法是 HEAD, 否則響應實體應該包含一個小型的超文字,標註一個超連結到新的URL。

範例

客戶端請求:

POST /blog/comment HTTP/1.1
Host: www.example.com
Content-Type:application/x-www-form-urlencoded; charset=UTF-8

伺服器回應:

HTTP/1.1 303 See Other
Location: http://www.example.org/view-comment.asp

參見

參考文獻

  1. ^ W3C: 10 Status Code Definitions. [2016-01-21]. (原始內容存檔於2010-03-16). 
  2. ^ Reference of method redirect_to in Ruby Web Framework "Ruby on Rails". It states: The redirection happens as a "302 Moved" header unless otherwise specified.. [June 30, 2012]. (原始內容存檔於2012-07-05). 
  3. ^ Hypertext Transfer Protocol (HTTP/1.1): Semantics and Content, Section 6.4. IETF. [June 12, 2014]. (原始內容存檔於2017-05-25). 

外部連結