request與response的做用

Request對象:爲腳本提供了當客戶端請求一個頁面或者傳遞一個窗體時,客戶端提供的所有信息。這包括能指明瀏覽器和用戶的HTTP變量,在這個域名下存放在瀏覽器中的cookie,任何做爲查詢字符串而附於URL後面的字符串或頁面的<FORM>段中的HTML控件的值。也提供使用Secure Socket Layer(SSL)或其餘加密通訊協議的受權訪問,及有助於對鏈接進行管理的屬性。
Response對象:用來訪問服務器端所建立的併發回到客戶端的響應信息。爲腳本提供HTTP變量,指明服務器和服務器的功能和關於發回瀏覽器的內容的信息,以及任何將爲這個域而存放在瀏覽器裏新的cookie。它也提供了一系列的方法用來建立輸出,例如無處不在的Response.Write方法。
cookie: Cookies是當你瀏覽某網站時,由Web服務器置於你硬盤上的一個很是小的文本文件,它能夠記錄你的用戶ID、密碼、瀏覽過的網頁、停留的時間等信息。 當你再次來到該網站時,網站經過讀取Cookies,得知你的相關信息,就能夠作出相應的動做,如在頁面顯示歡迎你的標語,或者讓你不用輸入ID、密碼就直接登陸等等。
講的通俗一點就是:
Request(中文「請求」的意思)類:能夠理解爲客戶端向服務器端請求的信息,就是客戶端向服務器端請求時,把本身的瀏覽器信息、HTTP變量和保存在客戶端的Cookie告訴服務器,這樣服務器端就能夠根據這些信息判斷①是誰請求的、②以前有沒有請求過、③對應客戶端的Session是什麼等等。
Response(中文「反應、響應」的意思)接口:能夠理解爲服務器對客戶端請求的響應,就是服務器接收到客戶端的請求後,成生頁面信息、Cookie(發到客戶端後就保存在客戶端)等發送到客戶端。
Cookie(中文「餅乾」,在這裏不能這樣理解了):就是保存在客戶端上的一些信息,能夠用來驗證用戶信息,提升用戶響應速度等等。爲什麼不把它理解爲:我把餅乾放在家裏,我想吃的時候就拿出來吃。呵呵!html

==============================================================java


response.sendRedirect()和request.getRequestDispatcher().forward(request,response)的區別
跳轉方式瀏覽器

=============================================================服務器

運用forward方法只能重定向到同一個Web應用程序中的一個資源。而sendRedirect方法可讓你重定向到任何URL。
表單form的action="/uu";sendRedirect("/uu");表示相對於服務器根路徑。如http://localhost:8080/Test應用(則提交至http://localhost:8080/uu);
Forward代碼中的"/uu"則表明相對與WEB應用的路徑。如http://localhost:8080/Test應用(則提交至http://localhost:8080/Test/uu);cookie


(運用RequestDispatcher接口的Forward)方法
forward()沒法重定向至有frame的jsp文件,能夠重定向至有frame的html文件,
同時forward()沒法在後面帶參數傳遞,好比servlet?name=frank,這樣不行,能夠程序內經過response.setAttribute("name",name)來傳至下一個頁面。
重定向後瀏覽器地址欄URL不變。併發

只有在客戶端沒有輸出時才能夠調用forward方法。若是當前頁面的緩衝區(buffer)不是空的,那麼你在調用forward方法前必須先清空緩衝區。
"/"表明相對與Web應用路徑jsp

RequestDispatcher rd = request.getRequestDispatcher("/ooo");
rd.forward(request, response);// 提交至http://localhost:8080/Test/ooo

RequestDispatcher rd = getServletContext().getRequestDispatcher("/ooo");
rd.forward(request, response);// 提交至http://localhost:8080/Test/ooo

RequestDispatcher rd =getServletContext().getNamedDispatcher("TestServlet");(TestServlet爲一個<servlet-name>)
rd.forward(request, response);// 提交至名爲TestServlet的servlet

若是在<jsp:forward>以前有不少輸出,前面的輸出已使緩衝區滿,將自動輸出到客戶端,那麼該語句將不起做用,這一點應該特別注意。
另外要注意:它不能改變瀏覽器地址,刷新的話會致使重複提交
從http://localhost:8080/Test/gw/page.jsp中轉發
 網站

<jsp:forward page="OtherPage.jsp"/>在JSP頁面被解析後轉換成pageContext.forward("OtherPage.jsp");
"/OtherPage.jsp"提交到http://localhost:8080/Test/OtherPage.jsp
"OtherPage.jsp"提交到http://localhost:8080/Test/gw/OtherPage.jsp

(運用HttpServletResponse接口的sendRedirect)方法302
是在用戶的瀏覽器端工做,sendRedirect()能夠帶參數傳遞,好比servlet?name=frank傳至下個頁面,
同時它能夠重定向至不一樣的主機上,sendRedirect()能夠重定向有frame.的jsp文件.ui

假設轉發代碼包含於註冊的servlet-url爲/ggg/tt;jsp爲/ggg/tt.jsp:
絕對路徑:response.sendRedirect("http://www.brainysoftware.com")發送至http://www.brainysoftware.com
根路徑:response.sendRedirect("/ooo")發送至http://localhost:8080/ooo
相對路徑:response.sendRedirect("ooo")發送至http://localhost:8080/Test/ggg/ooo,加密

sendRedirect等同於此方式
response.setStatus(HttpServletResponse.SC_MOVED_PERMANENTLY);
String newLocn = "/newpath/jsa.jsp";
response.setHeader("Location",newLocn);


(Meta Refresh)方法200
這種方法是由HTML提供的,Meta自己就是HTML標籤。使用方法是:<meta http-equiv="refresh" content="5; url=http://www.dreamdu.com/" />
相應的java代碼
String content=stayTime+";URL="+URL;
response.setHeader("REFRESH",content);
--------------------------------------------------------------------------------------------------------------------------
使用response.sendRedirect()地址欄將改變
使用request.getRequestDispatcher().forward(request,response)地址欄中的信息保持不變.
--------------------------------------------------------------------------------------------------------------------------
request.setAttribute存的東西
只用經過方法2跳轉 才能在新頁取出來
--------------------------------------------------------------------------------------------------------------------------
redirect 會首先發一個response給瀏覽器, 而後瀏覽器收到這個response後再發一個requeset給服務器, 而後服務器發新的response給瀏覽器. 這時頁面收到的request是一個新從瀏覽器發來的.

forward 發生在服務器內部, 在瀏覽器徹底不知情的狀況下發給了瀏覽器另一個頁面的response. 這時頁面收到的request不是從瀏覽器直接發來了,可能己經放了數據.

因此:
request.setAttribute存的東西

只用經過方法2跳轉才能在新頁取出來

相關文章
相關標籤/搜索