Java中轉(zhuǎn)發(fā)和重定向區(qū)別詳解

在使用servlet/jsp的時候败徊,我們必須要知道實現(xiàn)頁面跳轉(zhuǎn)的兩種方式的區(qū)別和聯(lián)系:
即轉(zhuǎn)發(fā)和重定向的區(qū)別。
1胎食、RequestDispatcher.forward方法只能將請求轉(zhuǎn)發(fā)給同一個WEB應(yīng)用中的組件;而HttpServletResponse.sendRedirect 方法不僅可以重定向到當前應(yīng)用程序中的其他資源谊惭,還可以重定向到同一個站點上的其他應(yīng)用程序中的資源蝙场,甚至是使用絕對URL重定向到其他站點的資源明场。如果傳遞給HttpServletResponse.sendRedirect 方法的相對URL以“/”開頭,它是相對于整個WEB站點的根目錄李丰;如果創(chuàng)建RequestDispatcher對象時指定的相對URL以“/”開頭苦锨,它是相對于當前WEB應(yīng)用程序的根目錄。
2趴泌、調(diào)用HttpServletResponse.sendRedirect方法重定向的訪問過程結(jié)束后舟舒,瀏覽器地址欄中顯示的URL會發(fā)生改變,由初始的URL地址變成重定向的目標URL嗜憔;而調(diào)用RequestDispatcher.forward 方法的請求轉(zhuǎn)發(fā)過程結(jié)束后秃励,瀏覽器地址欄保持初始的URL地址不變。
3吉捶、HttpServletResponse.sendRedirect方法對瀏覽器的請求直接作出響應(yīng)夺鲜,響應(yīng)的結(jié)果就是告訴瀏覽器去重新發(fā)出對另外一個URL的 訪問請求,這個過程好比有個綽號叫“瀏覽器”的人寫信找張三借錢呐舔,張三回信說沒有錢币励,讓“瀏覽器”去找李四借,并將李四現(xiàn)在的通信地址告訴給了“瀏覽器”珊拼。于是食呻,“瀏覽器”又按張三提供通信地址給李四寫信借錢,李四收到信后就把錢匯給了“瀏覽器”澎现〗霭可見,“瀏覽器”一共發(fā)出了兩封信和收到了兩次回復(fù)剑辫, “瀏覽器”也知道他借到的錢出自李四之手干旧。RequestDispatcher.forward方 法在服務(wù)器端內(nèi)部將請求轉(zhuǎn)發(fā)給另外一個資源,瀏覽器只知道發(fā)出了請求并得到了響應(yīng)結(jié)果妹蔽,并不知道在服務(wù)器程序內(nèi)部發(fā)生了轉(zhuǎn)發(fā)行為椎眯。這個過程好比綽號叫“瀏覽器”的人寫信找張三借錢,張三沒有錢讹开,于是張三找李四借了一些錢盅视,甚至還可以加上自己的一些錢捐名,然后再將這些錢匯給了“瀏覽器”旦万。可見镶蹋,“瀏覽器”只發(fā) 出了一封信和收到了一次回復(fù)成艘,他只知道從張三那里借到了錢赏半,并不知道有一部分錢出自李四之手。
4淆两、RequestDispatcher.forward方法的調(diào)用者與被調(diào)用者之間共享相同的request對象和response對象断箫,它們屬于同一個訪問請求和響應(yīng)過程;而HttpServletResponse.sendRedirect方法調(diào)用者與被調(diào)用者使用各自的request對象和response對象秋冰,它們屬于兩個獨立的訪問請求和響應(yīng)過程仲义。對于同一個WEB應(yīng)用程序的內(nèi)部資源之間的跳轉(zhuǎn),特別是跳轉(zhuǎn)之前要對請求進行一些前期預(yù)處理剑勾,并要使用HttpServletRequest.setAttribute方法傳遞預(yù)處理結(jié)果埃撵,那就應(yīng)該使用RequestDispatcher.forward方法。不同WEB應(yīng)用程序之間的重定向虽另,特別是要重定向到另外一個WEB站點上的資源的情況暂刘,都應(yīng)該使用HttpServletResponse.sendRedirect方法。
5捂刺、無論是RequestDispatcher.forward方法谣拣,還是HttpServletResponse.sendRedirect方法,在調(diào)用它們之前族展,都不能有內(nèi)容已經(jīng)被實際輸出到了客戶端森缠。如果緩沖區(qū)中已經(jīng)有了一些內(nèi)容,這些內(nèi)容將被從緩沖區(qū)中仪缸。
以上五點的論述來源于:https://blog.csdn.net/xybelieve1990/article/details/49486751
轉(zhuǎn)發(fā)和重定向的圖解

圖解

兩種跳轉(zhuǎn)獲得對象的方式

//獲得轉(zhuǎn)發(fā)對象getRequestDispatcher()
HttpServletRequest(httpServletRequest).getRequestDispatcher
ServletContext.getRequestDispatcher();
 
//獲得重定向?qū)ο髎endRedirect()
HttpServletResponse(httpServletResponse).sendRedirect();

轉(zhuǎn)發(fā)和跳轉(zhuǎn)的小結(jié)

1辅鲸、轉(zhuǎn)發(fā)使用的是getRequestDispatcher()方法;重定向使用的是sendRedirect();
2、轉(zhuǎn)發(fā):瀏覽器URL的地址欄不變腹殿。重定向:瀏覽器URL的地址欄改變独悴;
3、轉(zhuǎn)發(fā)是服務(wù)器行為锣尉,重定向是客戶端行為刻炒;
4、轉(zhuǎn)發(fā)是瀏覽器只做了一次訪問請求自沧。重定向是瀏覽器做了至少兩次的訪問請求坟奥;
5、轉(zhuǎn)發(fā)2次跳轉(zhuǎn)之間傳輸?shù)男畔⒉粫G失拇厢,重定向2次跳轉(zhuǎn)之間傳輸?shù)男畔G失(request范圍)爱谁。

轉(zhuǎn)發(fā)和重定向的選擇

1、重定向的速度比轉(zhuǎn)發(fā)慢孝偎,因為瀏覽器還得發(fā)出一個新的請求访敌,如果在使用轉(zhuǎn)發(fā)和重定向都無所謂的時候建議使用轉(zhuǎn)發(fā)。
2衣盾、因為轉(zhuǎn)發(fā)只能訪問當前WEB的應(yīng)用程序寺旺,所以不同WEB應(yīng)用程序之間的訪問爷抓,特別是要訪問到另外一個WEB站點上的資源的情況,這個時候就只能使用重定向了阻塑。
轉(zhuǎn)發(fā)和重定向的應(yīng)用場景
在上面我已經(jīng)提到了蓝撇,轉(zhuǎn)發(fā)是要比重定向快,因為重定向需要經(jīng)過客戶端陈莽,但是渤昌,轉(zhuǎn)發(fā)沒有。但是有時候走搁,采用重定向會更好耘沼,若需要重定向到另外一個外部網(wǎng)站,則無法使用轉(zhuǎn)發(fā)朱盐。另外群嗤,重定向還有一個應(yīng)用場景:避免在用戶重新加載頁面時兩次調(diào)用相同的動作。
例如兵琳,當提交產(chǎn)品表單的時候狂秘,執(zhí)行保存的方法將會被調(diào)用,并執(zhí)行相應(yīng)的動作躯肌;這在一個真實的應(yīng)用程序中者春,很有可能將表單中的所有產(chǎn)品信息加入到數(shù)據(jù)庫中。但是如果在提交表單后清女,重新加載頁面钱烟,執(zhí)行保存的方法就很有可能再次被調(diào)用。同樣的產(chǎn)品信息就將可能再次被添加嫡丙,為了避免這種情況拴袭,提交表單后,你可以將用戶重定向到一個不同的頁面曙博,這樣的話拥刻,這個網(wǎng)頁任意重新加載都沒有副作用;
但是父泳,使用重定向的一個不便之處是般哼,無法將值輕松地傳遞給目標頁面。而采用轉(zhuǎn)發(fā)惠窄,則可以簡單地將屬性添加到Model,使得目標視圖可以輕松訪問蒸眠。由于重定向經(jīng)過客戶端,所以Model中的一切都會在重定向時丟失杆融。但幸運的是楞卡,在Spring3.1版本以后,我們可以通過Flash屬性,解決重定向時傳值丟失的問題臀晃。
要使用Flash屬性,必須在Spring MVC的配置文件中添加一個<annotation-driven/>介劫。然后徽惋,還必須再方法上添加一個新的參數(shù)類型:

org.springframework.web.servlet.mvc.support.RedirectAttributes。

如下所示:

@RequestMapping(value="saveProduct",method=RequestMethod.POST)
public String saveProduct(ProductForm productForm,RedirectAttributes redirectAttributes){
 
     //執(zhí)行產(chǎn)品保存的業(yè)務(wù)邏輯等
  
     //傳遞參數(shù)
       redirectAttributes.addFlashAttribute("message","The product is saved successfully");
   
     //執(zhí)行重定向
      return "redirect:/……";
}
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末座韵,一起剝皮案震驚了整個濱河市险绘,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌誉碴,老刑警劉巖宦棺,帶你破解...
    沈念sama閱讀 222,378評論 6 516
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異黔帕,居然都是意外死亡代咸,警方通過查閱死者的電腦和手機,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 94,970評論 3 399
  • 文/潘曉璐 我一進店門成黄,熙熙樓的掌柜王于貴愁眉苦臉地迎上來呐芥,“玉大人,你說我怎么就攤上這事奋岁∷嘉粒” “怎么了?”我有些...
    開封第一講書人閱讀 168,983評論 0 362
  • 文/不壞的土叔 我叫張陵闻伶,是天一觀的道長滨攻。 經(jīng)常有香客問我,道長蓝翰,這世上最難降的妖魔是什么光绕? 我笑而不...
    開封第一講書人閱讀 59,938評論 1 299
  • 正文 為了忘掉前任,我火速辦了婚禮畜份,結(jié)果婚禮上奇钞,老公的妹妹穿的比我還像新娘。我一直安慰自己漂坏,他們只是感情好景埃,可當我...
    茶點故事閱讀 68,955評論 6 398
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著顶别,像睡著了一般谷徙。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上驯绎,一...
    開封第一講書人閱讀 52,549評論 1 312
  • 那天完慧,我揣著相機與錄音,去河邊找鬼剩失。 笑死屈尼,一個胖子當著我的面吹牛册着,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播脾歧,決...
    沈念sama閱讀 41,063評論 3 422
  • 文/蒼蘭香墨 我猛地睜開眼甲捏,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了鞭执?” 一聲冷哼從身側(cè)響起司顿,我...
    開封第一講書人閱讀 39,991評論 0 277
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎兄纺,沒想到半個月后大溜,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 46,522評論 1 319
  • 正文 獨居荒郊野嶺守林人離奇死亡估脆,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 38,604評論 3 342
  • 正文 我和宋清朗相戀三年钦奋,在試婚紗的時候發(fā)現(xiàn)自己被綠了。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片疙赠。...
    茶點故事閱讀 40,742評論 1 353
  • 序言:一個原本活蹦亂跳的男人離奇死亡锨苏,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出棺聊,到底是詐尸還是另有隱情伞租,我是刑警寧澤,帶...
    沈念sama閱讀 36,413評論 5 351
  • 正文 年R本政府宣布限佩,位于F島的核電站葵诈,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏祟同。R本人自食惡果不足惜作喘,卻給世界環(huán)境...
    茶點故事閱讀 42,094評論 3 335
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望晕城。 院中可真熱鬧泞坦,春花似錦、人聲如沸砖顷。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,572評論 0 25
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽滤蝠。三九已至豌熄,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間物咳,已是汗流浹背锣险。 一陣腳步聲響...
    開封第一講書人閱讀 33,671評論 1 274
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人芯肤。 一個月前我還...
    沈念sama閱讀 49,159評論 3 378
  • 正文 我出身青樓巷折,卻偏偏與公主長得像,于是被迫代替她去往敵國和親崖咨。 傳聞我的和親對象是個殘疾皇子锻拘,可洞房花燭夜當晚...
    茶點故事閱讀 45,747評論 2 361

推薦閱讀更多精彩內(nèi)容