HTTP 307

HTTP回應狀態碼

307 Temporary RedirectHTTP協議中的一個狀態碼(Status Code)。可以理解為一個臨時的重定向[1]

但該響應代碼與302重定向有所區別的地方在於,收到307響應碼後,客戶端應保持請求方法不變向新的地址發出請求。[2]

引入

雖然RFC 1945RFC 2068規範不允許客戶端在重定向時改變請求的方法,但是很多現存的瀏覽器在收到302響應時,直接使用GET方式訪問在Location頭部中規定的URI,而無視原先請求的方法。[3]

因此,狀態碼307被添加了進來,用以明確服務器期待客戶端進行何種反應。[4]

特徵

根據RFC 2616定義:

  • 響應實體必須帶有一個HTTP Location頭部來指示新地址。
  • 如果一個客戶端有鏈接編輯能力,其應當把所有的引用鏈接重定向到新的URL上。
  • 除非帶有Cache-Control或Expires頭部,否則該響應不能被緩存。
  • 除非請求方法是HEAD,否則響應實體應該包含一個小型的超文本,標註一個超鏈接到新的URL。
  • 如果是除了GET和HEAD之外的請求方法,客戶端必須在重定向之前詢問用戶。

示例

以GET方式請求

GET /index.php HTTP/1.1
Host: www.example.org

服務器回應:

HTTP/1.1 307 Temporary Redirect
Location: https://www.example.org/

服務器配置

這是一個例子,展示如何使用Nginx返回307重定向:

location /old/url/ {
    return 307 /new/url;
}

這是使用PHP實現307重定向的方式:

<?php
header("HTTP/1.1 307 Temporary Redirect");
header("Location: http://example.com/newpage.html");
exit();
?>


用途

  • 該響應碼被用於Chrome,用來在本地對已經緩存的HSTS站點進行重定向。[5]
  • 該響應碼也常用於客戶端發出PUT請求,但非上傳具體文件時,服務器向客戶端返回確認用的文本消息。[2]

參見

參考文獻

  1. ^ HTTP/1.1: Status Code Definitions. [2017-06-30]. (原始內容存檔於2010-03-16). 
  2. ^ 2.0 2.1 307 Temporary Redirect. Mozilla Developer Network. [2017-07-04]. (原始內容存檔於2017-07-02). 
  3. ^ 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.. [2012-06-30]. (原始內容存檔於2012-07-05). 
  4. ^ Hypertext Transfer Protocol (HTTP/1.1): Semantics and Content, Section 6.4. IETF. [2014-06-12]. (原始內容存檔於2017-05-25). 
  5. ^ Understanding the "Fake 307" redirects in Chrome. cemper.academy. [2017-07-04]. (原始內容存檔於2017-07-13). 

外部連結