您好,登錄后才能下訂單哦!
這篇文章將為大家詳細講解有關Servlet/JSP服務器端如何實現重定向,小編覺得挺實用的,因此分享給大家做個參考,希望大家閱讀完這篇文章后可以有所收獲。
JSP服務器端的重定向相關類
JSP服務器端的重定向技術涉及到javax.servlet.ServletContext、javax.servlet.RequestDispatcher、javax.servlet.http.ServletRequest、javax.servlet.http.ServletResponse等幾個接口。
JSP服務器端的重定向方式
JSP服務器端的重定向可以有兩種方式,一是使用HttpServletResponse的sendRedirect()方法,一是使用RequestDispatcher的forward()方法。下面對這兩種方式進行介紹。
HttpServletResponse.sendRedirect()方法
HttpServletResponse接口定義了可用于轉向的sendRedirect()方法。代碼如下:
public void sendRedirect(java.lang.String location)throws java.io.IOException
這個方法將響應定向到參數location指定的、新的URL。location可以是一個絕對的URL,如response.sendRedirect("http://java.sun.com")也可以使用相對的URL。如果location以“/”開頭,則容器認為相對于當前Web應用的根,否則,容器將解析為相對于當前請求的URL。這種重定向的方法,將導致客戶端瀏覽器的請求URL跳轉。從瀏覽器中的地址欄中可以看到新的URL地址,作用類似于上面設置HTTP響應頭信息的實現。
RequestDispatcher.forward()方法
RequestDispatcher是一個Web資源的包裝器,可以用來把當前request傳遞到該資源,或者把新的資源包括到當前響應中。RequestDispatcher接口中定義了兩個方法,參見如下代碼:
public interface RequestDispatcher {void forward(ServletRequest request, ServletResponse response); void include(ServletRequest request, ServletResponse response);}
forward()方法將當前的request和response重定向到該RequestDispacher指定的資源。這在實際項目中大量使用,因為完成一個業務操作往往需要跨越多個步驟,每一步驟完成相應的處理后,轉向到下一個步驟。比如,通常業務處理在Servlet中處理,處理的結果轉向到一個JSP頁面進行顯示。這樣看起來類似于Servlet鏈的功能,但是還有一些區別。一個RequestDispatcher對象可以把請求發送到任意一個服務器資源,而不僅僅是另外一個Servlet。 include()方法將把Request Dispatcher資源的輸出包含到當前輸出中。
注意,只有在尚未向客戶端輸出響應時才可以調用forward()方法,如果頁面緩存不為空,在重定向前將自動清除緩存。否則將拋出一個IllegalStateException異常。
如何得到RequestDispatcher
有三種方法可以得到Request Dispatcher對象。
1.javax.servlet. ServletRequest的getRequestDispatcher(String path)方法,其中path可以是相對路徑,但不能越出當前Servlet上下文。如果path以“/”開頭,則解析為相對于當前上下文的根。
2.javax.servlet. ServletContext的getRequestDispatcher(String path)方法,其中path必須以“/”開頭,路徑相對于當前的Servlet上下文。可以調用ServletContext的getContext(String uripath)得到另一個Servlet上下文,并可以轉向到外部上下文的一個服務器資源鏈接。
3.使用javax.servlet. ServletContext的getNamedDispatcher(String name)得到名為name的一個Web資源,包括Servlet和JSP頁面。這個資源的名字在Web應用部署描述文件web.xml中指定。
這三種方法的使用有細微的差別。比如,下面是一個應用的配置文件web.xml:
<?xml version="1.0" ?><!DOCTYPE web-app PUBLIC "-//Sun Microsystems, Inc.//DTD Web Application 2.2//EN" "http://java.sun.com/j2ee/dtds/web-app_2_2.dtd"><web-app><servlet><servlet-name>FirstServlet</servlet-name><servlet-class>org. javaresearch.redirecttest.ServletOne</servlet-class></servlet><servlet><servlet-name>SecondServlet</servlet-name><servlet-class>org.javaresearch. redirecttest.ServletTwo</servlet-class></servlet><servlet-mapping><servlet-name>FirstServlet</servlet-name><url-pattern>/servlet/firstservlet/</url-pattern></servlet-mapping><servlet-mapping><servlet-name>SecondServlet</servlet-name><url-pattern>/servlet/secondservlet/</url-pattern></servlet-mapping></web-app>
其中定義了兩個Servlet,名字分別為FirstServlet和SecondServlet,對應的類分別為org.javaresearch. redirecttest.ServletOne和org. javaresearch.redirecttest.ServletTwo。可以在瀏覽器中通過類似于下面的鏈接訪問:
http://localhost:8080/servlet/firstservlet/
使用1中方法,例如在firstservlet可以寫入下面的代碼:
RequestDispatcher rd = request.getRequestDispatcher("secondservlet");rd.forward(request, response);
此時控制權將轉向到第二個Servlet了。
使用2中的方法,可以從Servlet Context中得到RequestDispatcher代碼如下:
RequestDispatcher rd = getServletContext().getRequest Dispatcher("/servlet/secondservlet");rd.forward(request, response);
使用3中的方法,從上面的web. xml配置文件可以看到定義了兩個Servlet,名字分別為FirstServlet和SecondServlet,所以可以得到命名的Dispatcher:
RequestDispatcher rd = getServletContext().getNamedDispatcher("SecondServlet");rd.forward(request, response);
這樣也可以重定向到SecondServlet了。
JSP頁面中的重定向
JSP在解析后編譯為一個Servlet運行,所以在JSP中也可以使用上面的重定向代碼,并且,JSP還提供了更便利的操作,如下:
<jsp:forward page= "nextpage.jsp"/>
JSP頁面執行到這兒,將終止當前的處理,將控制權交由nextpage.jsp。
如何選擇JSP服務器端
RequestDispatcher.forward()方法和HttpServletResponse.sendRedirect()方法的區別是:前者僅是容器中控制權的轉向,在客戶端瀏覽器地址欄中不會顯示出轉向后的地址;后者則是完全的跳轉,瀏覽器將會得到跳轉的地址,并重新發送請求鏈接。這樣,從瀏覽器的地址欄中可以看到跳轉后的鏈接地址。所以,前者更加高效,在前者可以滿足需要時,盡量使用Request Dispatcher.forward()方法,并且,這樣也有助于隱藏實際的鏈接。在有些情況下,比如,需要跳轉到一個其它服務器上的資源,則必須使用HttpServletResponse.sendRequest()方法。
關于“Servlet/JSP服務器端如何實現重定向”這篇文章就分享到這里了,希望以上內容可以對大家有一定的幫助,使各位可以學到更多知識,如果覺得文章不錯,請把它分享出去讓更多的人看到。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。