面試突擊66:請求轉發和請求重定向有什麼區別?

2022-07-18 12:03:37


在 Java 中,跳轉的實現方式有兩種:請求轉發和請求重定向,但二者是完全不同的,所以我們今天就來盤它。
請求轉發和請求重定向主要區別,包含以下 5 點:

  1. 定義不同
  2. 跳轉方不同
  3. 資料共用不同
  4. 最終 URL 地址不同
  5. 程式碼實現不同

接下來,我們一個一個來看。

1.定義不同

請求轉發(Forward):發生在伺服器端程式內部,當伺服器端收到一個使用者端的請求之後,會先將請求,轉發給目標地址,再將目標地址返回的結果轉發給使用者端。而使用者端對於這一切毫無感知的,這就好比,張三(使用者端)找李四(伺服器端)借錢,而李四沒錢,於是李四又去王五那借錢,並把錢借給了張三,整個過程中張三隻借了一次款,剩下的事情都是李四完成的,這就是請求轉發。
請求重定向(Redirect):請求重定向指的是伺服器端接收到使用者端的請求之後,會給使用者端返回了一個臨時響應頭,這個臨時響應頭中記錄了,使用者端需要再次傳送請求(重定向)的 URL 地址,使用者端再收到了地址之後,會將請求傳送到新的地址上,這就是請求重定向。這就好像張三(使用者端)找李四(伺服器端)借錢,李四沒錢,於是李四就告訴張三,「我沒錢,你去王五那借「,於是張三又去王五家借到了錢,這就是請求重定向。

2.請求方不同

從上面請求轉發和請求重定向的定義,我們可以看出:請求轉發是伺服器端的行為,伺服器端代替使用者端傳送請求,並將結果返回給使用者端;而請求重定向是使用者端的行為,它們的互動流程,如下圖所示:

3.資料共用不同

請求轉發是伺服器端實現的,所以整個執行流程中,使用者端(瀏覽器端)只需要傳送一次請求,因此整個互動過程中使用的都是同一個 Request 請求物件和一個 Response 響應物件,所以整個請求過程中,請求和返回的資料是共用的;而請求重定向使用者端傳送兩次完全不同的請求,所以兩次請求中的資料是不同的。

4.最終 URL 地址不同

請求轉發是伺服器端代為請求,再將結果返回給使用者端的,所以整個請求的過程中 URL 地址是不變的;而請求重定向是伺服器端告訴使用者端,「你去另一個地存取去」,所以瀏覽器會重新再傳送一次請求,因此使用者端最終顯示的 URL 也為最終跳轉的地址,而非剛開始請求的地址,所以 URL 地址發生了改變。

5.程式碼實現不同

在 SpringBoot 中,請求轉發的實現程式碼如下:

@RequestMapping("/fw")
public void forward(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
    request.getRequestDispatcher("/index.html").forward(request, response);
}

而請求重定向的實現程式碼如下:

@RequestMapping("/rt")
public void redirect(HttpServletRequest request, HttpServletResponse response) throws IOException {
    response.sendRedirect("/index.html");
}

總結

請求轉發和請求重定向遵循的是「字越少,事越大」的原則,「請求轉發」的字比較少,它需要代使用者端執行跳轉;而「請求重定向」字比較多,它啥也不幹,只是告訴使用者端「你去別的地兒存取」就行了,這就是理解這兩個概念的關鍵。它們的區別主要體現在 5 個點:定義不同、請求方不同、資料共用不同、最終 URL 地址不同、程式碼實現不同。

參考 & 鳴謝

www.jianshu.com/p/81407dff803d
www.cnblogs.com/su-chu-zhi-151/p/11875641.html

是非審之於己,譭譽聽之於人,得失安之於數。

公眾號:Java面試真題解析

面試合集:https://gitee.com/mydb/interview