response的兩種跳轉方式

response.sendRedirect方式的轉向與RequestDispatcher的forward方法的比較

Java Web開發中,採用MVC模式的時候,在控制器完成模型的調用之後會選擇界面對用戶響應,用常有兩種方式:

1、通過response對象的sendRedirect方法。

2、通過RequestDispatcher對象的forward方法。

例如要跳轉登錄界面login.jsp,可以使用下面的兩種方式:

1、使用response

response.sendRedirect("login.jsp");

2、使用RequestDispatcher

RequestDispatcher rd = request.getRequestDispatcher("login.jsp");

rd.forward(request,response);

這兩種方式有什麼區別?什麼情況下應該使用哪一種方式呢?

首先介紹兩者的區別。

第一點區別,過程不同:第一種方式相當於瀏覽器接收到了響應之後又向服務器發送了一次請求,所以相當於兩次請求。第二種方式相當於方法調用,在執行當前文件的過程中轉向執行目標文件,兩個文件(當前文件和目標文件)屬於同一次請求,最本質的特點就是兩次請求共享了reques對象和response對象。

第二點區別,地址欄不同:第一種方式下用戶在瀏覽器地址欄中看到的是目標文件的地址,第二種方式下用戶在瀏覽器地址欄中看到的是當前文件的地址。這一點也非常重要,後面介紹。

在使用的時候具體應如何選擇呢?

如果兩個文件的關係非常密切,則應該使用RequestDispatcher,如果兩個文件沒有直接的關聯關係,則應該使用response的sendRedirect方法。什麼樣的關係算是關係密切,什麼樣的關係算是沒有直接的關聯關係呢?例如查詢的控制器和查詢的結果界面之間就應該算是關係密切,因爲查詢控制器處理完之後肯定要轉向查詢結果界面。再例如添加信息的控制器和查詢控制器之間的關係就是沒有直接關係,通常在添加信息之後會跳轉到列表界面的控制器然後再跳轉到列表界面,修改信息或者刪除信息之後也可能會跳轉到列表界面的控制器然後再跳轉到列表界面。

下面是兩個比較特殊的應用:

1、如果希望通過request把當前在控制器中獲取的信息傳遞給目標文件(通過request.setAttribute和request.getAttribute),這時候應該選擇RequestDispatcher。因爲需要當前文件和目標文件共享request對象。通常用於查詢。

2、對數據進行修改(包括刪除和添加操作)的功能的控制器與之後的界面或者控制器應該採用response.sendRedirect方式。如果採用了RequestDiapatcher的forward方式,會產生嚴重錯誤。因爲地址欄是修改信息的控制器,如果用戶在刷新的時候,會重新發送一次對數據進行修改的請求,這不是用戶想看到的結果。所以有同學在做添加功能的時候,每刷新一次就添加一條。

如何採用第二種方式,如何傳遞數據呢?有兩種方式:

1、可以選擇session,但是在第二個文件中一定要刪除。

2、可以在請求字符串中編寫,例如login.jsp?info="用戶不存在!"

轉的sina博客.

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章