forward sendredirect 區別

來源:互聯網
上載者:User

sendRedirect&forward
關鍵詞: sendRedirect&fo                                          
1.sendRedirect時,伺服器端先響應用戶端一個狀態代碼(通常是302),告訴用戶端應該向location前序指定的URL(可以是相對路徑)重新發送請求。然後用戶端按照指示進行第二次請求;
2.forward時,操作完全在伺服器端進行,由伺服器直接執行新的URL。用戶端甚至毫不知情。
3.由於sendRedirect是由用戶端自動請求的,所以客戶的第一次的請求資料就不能得到儲存;相反,在forward的情況,客戶第一次的請求資料得到了儲存,即在新的URL裡能夠得到原先的請求資料。
4.在相同的情況下,由於sendRedirect相當於客戶的兩次請求,所以forward的效率較sendRedirect要好

 

 

 

 

以下轉自:http://kevinmro.bokee.com/546919.html

 

 

forward()就是轉寄。sendRedirect就是重新導向。兩者最大的區別就是一個是:
forward()執行後還是在同一個requestrequest範圍,
而sendRedirect執行之後就不在同一個request範圍裡面。

 

1.RequestDispatcher.forward()

    是在伺服器端起作用,當使用forward()時,Servletengine傳遞HTTP請求從當前的Servlet or JSP到另外一個Servlet,JSP 或普通HTML檔案,也即你的form提交至a.jsp,在a.jsp用到了forward()重新導向至b.jsp,此時form提交的所有資訊在 b.jsp都可以獲得,參數自動傳遞.但forward()無法重新導向至有frame的jsp檔案,可以重新導向至有frame的html檔案,同時forward()無法在後面帶參數傳遞,比如servlet?name=frank,這樣不行,可以程式內通過response.setAttribute("name",name)來傳至下一個頁面(註:這個我的理解是通過參數記錄,然後在架構頁面中用參數來設定架構內頁的地址) .重新導向後瀏覽器地址欄URL不變.     因為完成一個業務操作往往需要跨越多個步驟,每一步驟完成相應的處理後,轉向到下一個步驟。比如,通常業務處理在Servlet中處理,處理的結果轉向到一個 JSP頁面進行顯示。這樣看起來類似於Servlet鏈的功能,但是還有一些區別。一個RequestDispatcher對象可以把請求發送到任意一個伺服器資源,而不僅僅是另外一個Servlet。注意,只有在尚未向用戶端輸出響應時才可以調用forward()方法,如果頁面緩衝不為空白,在重新導向前將自動清除緩衝。否則將拋出一個異常例:servlet檔案中重新導向public void doPost(HttpServletRequest request,HttpServletResponse response)        throws ServletException,IOException{        response.setContentType("text/html; charset=gb2312");        ServletContext sc = getServletContext();        RequestDispatcher rd = null;        rd = sc.getRequestDispatcher("/index.jsp");        rd.forward(request, response);}     
 
2.response.sendRedirect()    是在使用者的瀏覽器端工作,sendRedirect()可以帶參數傳遞,比如servlet?name=frank傳至下個頁面,同時它可以重新導向至不同的主機上,且在瀏覽器地址欄上會出現重新導向頁面的URL.    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回應標頭資訊的實現 3。如何得到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。 4。如何選擇RequestDispatcher.forward()方法和HttpServletResponse.sendRedirect()方法的區別是:前者僅是容器中控制權的轉向,在用戶端瀏覽器地址欄中不會顯示出轉向後的地址;後者則是完全的跳轉,瀏覽器將會得到跳轉的地址,並重新發送請求連結。這樣,從瀏覽器的地址欄中可以看到跳轉後的連結地址。所以,前者更加高效,在前者可以滿足需要時,盡量使用Request Dispatcher.forward()方法,並且,這樣也有助於隱藏實際的連結。在有些情況下,比如,需要跳轉到一個其它伺服器上的資源,則必須使用 HttpServletResponse.sendRequest()方法。

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.