作者:@haimishasha
本文為作者原創,轉載請注明出處:https://www.cnblogs.com/haimishasha/p/5952129.html
用戶向服務器發送了一次HTTP請求,該請求肯能會經過多個信息資源處理以后才返回給用戶,各個信息資源使用請求轉發機制相互轉發請求,但是用戶是感覺不到請求轉發的。根據轉發方式的不同,可以區分為直接請求轉發(Forward)和間接請求轉發(Redirect)兩種有何區別呢?本篇在回答該問題的同時全面的講解兩種請求轉發方式的原理和區別。
【關鍵考點】
- 請求轉發的含義;
- Forward轉發請求的原理;
- Redirect轉發請求的原理。
【考題分析】
Forward和Redirect代表了兩種請求轉發方式:直接轉發和間接轉發。
直接轉發方式(Forward),客戶端和瀏覽器只發出一次請求,Servlet、HTML、JSP或其它信息資源,由第二個信息資源響應該請求,在請求對象request中,保存的對象對於一個每個信息資源是共享的。
間接轉發方式(Redirect)實際是兩次HTTP請求,服務器端在響應第一次請求的時候,讓瀏覽器再向另外一個URL發出請求,從而達到轉發的目的。
最明顯的區別就是:
redirect() 會丟失request的所有信息 它屬於頁面級的重定向,僅僅讓你的瀏覽器重新訪問一個新的url,作為瀏覽者,能很明顯的看到瀏覽器url地址的變化,這和點擊了一個普通的超鏈接的后果是一樣的。
而 RequestDispatcher 的forward() 方法,是轉發,需要request 和 response最為參數,就是將用戶的請求,連同請求信息等內容,一起轉發到服務器的另外一個servlet去處理,它不會丟失request信息。這一過程是服務器內部完成的,作為訪問者,是感覺不到了,或者說是透明的,因此訪客瀏覽器的url 是不會發生變化的。
舉個通俗的例子:
直接轉發就相當於:“A找B借錢,B說沒有,B去找C借,借到借不到都會把消息傳遞給A”;
間接轉發就相當於:"A找B借錢,B說沒有,讓A去找C借"。
下面詳細闡述一下兩者的原理:
一:間接請求轉發(Redirect)
間接轉發方式,有時也叫重定向,它一般用於避免用戶的非正常訪問。例如:用戶在沒有登錄的情況下訪問后台資源,Servlet可以將該HTTP請求重定向到登錄頁面,讓用戶登錄以后再訪問。在Servlet中,通過調用response對象的SendRedirect()方法,告訴瀏覽器重定向訪問指定的URL,示例代碼如下:
|
1
2
3
4
5
6
7
|
......
//Servlet中處理get請求的方法
public
void
doGet(HttpServletRequest request,HttpServletResponse response){
//請求重定向到另外的資源
response.sendRedirect(
"資源的URL"
);
}
........
|

上圖所示的間接轉發請求的過程如下:
- 瀏覽器向Servlet1發出訪問請求;
- Servlet1調用sendRedirect()方法,將瀏覽器重定向到Servlet2;
- 瀏覽器向servlet2發出請求;
- 最終由Servlet2做出響應。
二:直接請求轉發(Forward)
直接轉發方式用的更多一些,一般說的請求轉發指的就是直接轉發方式。Web應用程序大多會有一個控制器。由控制器來控制請求應該轉發給那個信息資源。然后由這些信息資源處理請求,處理完以后還可能轉發給另外的信息資源來返回給用戶,這個過程就是經典的MVC模式。
javax.serlvet.RequestDispatcher接口是請求轉發器必須實現的接口,由Web容器為Servlet提供實現該接口的對象,通過調用該接口的forward()方法到達請求轉發的目的,示例代碼如下:
|
1
2
3
4
5
6
7
8
|
......
//Servlet里處理get請求的方法
public
void
doGet(HttpServletRequest request , HttpServletResponse response){
//獲取請求轉發器對象,該轉發器的指向通過getRequestDisPatcher()的參數設置
RequestDispatcher requestDispatcher =request.getRequestDispatcher(
"資源的URL"
);
//調用forward()方法,轉發請求
requestDispatcher.forward(request,response);
}......
|

上圖所示的直接轉發請求的過程如下:
- 瀏覽器向Servlet1發出訪問請求;
- Servlet1調用forward()方法,在服務器端將請求轉發給Servlet2;
- 最終由Servlet2做出響應。
技巧: 其實,通過瀏覽器就可以觀察到服務器端使用了那種請求轉發方式,當單機某一個超鏈接時,瀏覽器的地址欄會出現當前請求的地址,如果服務器端響應完成以后,發現地址欄的地址變了,則證明是間接的請求轉發。相反,如果地址沒有發生變化,則代表的是直接請求轉發或者沒有轉發。
問:直接轉發和間接轉發的原理及區別是什么?
答:Forward和Redirect代表了兩種請求轉發方式:直接轉發和間接轉發。對應到代碼里,分別是RequestDispatcher類的forward()方法和HttpServletRequest類的sendRedirect()方法。
對於間接方式,服務器端在響應第一次請求的時候,讓瀏覽器再向另外一個URL發出請求,從而達到轉發的目的。它本質上是兩次HTTP請求,對應兩個request對象。
對於直接方式,客戶端瀏覽器只發出一次請求,Servlet把請求轉發給Servlet、HTML、JSP或其它信息資源,由第2個信息資源響應該請求,兩個信息資源共享同一個request對象。
