在學習Servlet和JSP時,經常會使用到forward和redirect,我們先來看這兩者在Servlet中的調用方式:
1.forward
request.getRequestDispatcher("new.jsp").forward(request, response); //轉發到new.jsp
2.redirect
response.sendRedirect("new.jsp"); //重定向到new.jsp
很明顯一個是用request對象調用,一個是用response對象調用,那么,這兩者有什么區別呢?
一、數據共享方面
forward:轉發頁面和轉發到的頁面可以共享request里面的數據
redirect:不能共享數據
二、地址欄顯示方面
forward是服務器請求資源,服務器直接訪問目標地址的URL,把那個URL的響應內容讀取過來,然后把這些內容再發給瀏覽器.瀏覽器根本不知道服務器發送的內容從哪里來的,所以它的地址欄還是原來的地址.
redirect是服務端根據邏輯,發送一個狀態碼,告訴瀏覽器重新去請求那個地址.所以地址欄顯示的是新的URL.
三、本質區別
轉發是服務器行為,重定向是客戶端行為。為什么這樣說呢,這就要看兩個動作的工作流程:
轉發過程:客戶瀏覽器發送http請求--->web服務器接受此請求--->調用內部的一個方法在容器內部完成請求處理和轉發動作--->將目標資源 發送給客戶;在這里,轉發的路徑必須是同一個web容器下的url,其不能轉向到其他的web路徑上去,中間傳遞的是自己的容器內的request。在客 戶瀏覽器路徑欄顯示的仍然是其第一次訪問的路徑,也就是說客戶是感覺不到服務器做了轉發的。轉發行為是瀏覽器只做了一次訪問請求。
重定向過程:客戶瀏覽器發送http請求--->web服務器接受后發送302狀態碼響應及對應新的location給客戶瀏覽器--->客戶瀏覽器發現 是302響應,則自動再發送一個新的http請求,請求url是新的location地址--->服務器根據此請求尋找資源並發送給客戶。在這里 location可以重定向到任意URL,既然是瀏覽器重新發出了請求,則就沒有什么request傳遞的概念了。在客戶瀏覽器路徑欄顯示的是其重定向的 路徑,客戶可以觀察到地址的變化的。重定向行為是瀏覽器做了至少兩次的訪問請求的。
重定向,其實是兩次request:第一次,客戶端request A,服務器響應,並response回來,告訴瀏覽器,你應該去B。這個時候IE可以看到地址變了,而且歷史的回退按鈕也亮了。重定向可以訪問自己web應用以外的資源。在重定向的過程中,傳輸的信息會被丟失。