您好,登錄后才能下訂單哦!
這篇文章主要介紹了Servlet怎么實現共享數據JavaWeb組件的相關知識,內容詳細易懂,操作簡單快捷,具有一定借鑒價值,相信大家閱讀完這篇Servlet怎么實現共享數據JavaWeb組件文章都會有所收獲,下面我們一起來看看吧。
Servlet JavaWeb三大組件包括,Servlet組件(接受請求,響應數據),Filter組件(過濾,攔截請求),Listener組件(監聽器),這三大組件構成了javaWeb核心內容,也是作為后端來說,JavaWeb最重要的內容。
Servlet是sun公司提供的一門用于開發動態web資源的技術。
Sun公司在其API中提供了一個servlet接口,用戶若想用發一個動態web資源(即開發一個Java程序向瀏覽器輸出數據),需要完成以下2個步驟:
1、編寫一個Java類,實現servlet接口。
2、把開發好的Java類部署到web服務器中。
按照一種約定俗成的稱呼習慣,通常我們也把實現了servlet接口的java程序,稱之為Servlet
Servlet程序是由WEB服務器調用,web服務器收到客戶端的Servlet訪問請求后:
①Web服務器首先檢查是否已經裝載并創建了該Servlet的實例對象。如果是,則直接執行第④步,否則,執行第②步。
②裝載并創建該Servlet的一個實例對象。
③調用Servlet實例對象的init()方法。
④創建一個用于封裝HTTP請求消息的HttpServletRequest對象和一個代表HTTP響應消息的HttpServletResponse對象,然后調用Servlet的service()方法并將請求和響應對象作為參數傳遞進去。
⑤WEB應用程序被停止或重新啟動之前,Servlet引擎將卸載Servlet,并在卸載之前調用Servlet的destroy()方法。
什么是Servlet組件:處理請求和發送響應的過程是由一種叫做Servlet的程序來完成的,并且Servlet是為了解決實現動態頁面而衍生的東西。
整個過程為:
客戶端發送請求至服務器端;服務器將請求信息發送至 Servlet;Servlet 生成響應內容并將其傳給服務器。響應內容動態生成,通常取決于客戶端的請求;服務器將響應返回給客戶端。
Servlet規范中提供四種數據共享方案:
ServletContext接口
HttpServletRequest接口
HttpSession接口
Cookie類
Request和Responserequest
和response
對象的原理:
==都由服務器創建,我們來使用它們;
==request對象是來獲取請求消息,response對象是來設置響應消息;
==request對象繼承體系結構:ServletRequest
接口
<<繼承>>HttpServletRequest
接口
<<實現>>
(tomcat類)org.apache.catalina.connector.RequestFacade
第一種 request.getRequestDispatcher().forward(request,response)
:
1、屬于轉發,也是服務器跳轉,相當于方法調用,在執行當前文件的過程中轉向執行目標文件,兩個文件(當前文件和目標文件)屬于同一次請求,前后頁共用一個request,可以通過此來傳遞一些數據或者session信息,request.setAttribute()
和request.getAttribute()
。
2、在前后兩次執行后,地址欄不變,仍是當前文件的地址。
3、不能轉向到本web應用之外的頁面和網站,所以轉向的速度要快。
4、URL中所包含的“/”表示應用程序(項目)的路徑。
第二種 response.sendRedirect()
:
1、屬于重定向,也是客戶端跳轉,相當于客戶端向服務端發送請求之后,服務器返回一個響應,客戶端接收到響應之后又向服務端發送一次請求,一共是2次請求,前后頁不共用一個request,不能讀取轉向前通過request.setAttribute()
設置的屬性值。
2、在前后兩次執行后,地址欄發生改變,是目標文件的地址。
3、可以轉向到本web應用之外的頁面和網站,所以轉向的速度相對要慢。
4、URL種所包含的"/"表示根目錄的路徑。
特殊的應用:對數據進行修改、刪除、添加操作的時候,應該用response.sendRedirect()
。如果是采用了request.getRequestDispatcher().forward(request,response)
,那么操作前后的地址欄都不會發生改變,仍然是修改的控制器,如果此時再對當前頁面刷新的話,就會重新發送一次請求對數據進行修改,這也就是有的人在刷新一次頁面就增加一條數據的原因。
如何采用第二種方式傳遞數據:
1、可以選擇session,但要在第二個文件中刪除;
2、可以在請求的url中帶上參數,如"add.htm?id=122"
典型的應用場景:
forward: 訪問 Servlet 處理業務邏輯,然后 forward 到 jsp 顯示處理結果,瀏覽器里 URL 不變
redirect: 提交表單,處理成功后 redirect 到另一個 jsp,防止表單重復提交,瀏覽器里 URL 變了
6. 開發人員習慣將ServletContext
對象稱為【全局作用域對象】
7. 工作原理:每個網站都存在一個全局作用域對象【相當于】一個Map;
將數據存入全局作業域對象,當前其他servlet此時都可以從全局作用域對象得到這個數據并進行使用;
8. 生命周期:Http服務器啟動過程中,自動在內存中創建一個全局作用域對象,在運行期間,全局作用域對象就一個,并且一直存活,當Http服務器關閉時,進行銷毀;
全局作用域對象生命周期貫穿網站整個運行周期
ServletContext
全局作用域對象,所有的Servlet共享這個對象
是一個域對象
可以讀取全局配置參數
可以搜索當前工程目錄下面的資源文件
可以獲取當前工程名字(了解)
凡是域對象都有如下3個方法:
setAttribute(name,value);
name是String類型,value是Object類型;往域對象里面添加數據,添加時以key-value形式添加
getAttribute(name);
根據指定的key讀取域對象里面的數據
removeAttribute(name);
根據指定的key從域對象里面刪除數據
HttpServletRequest
對象代表客戶端的請求,當客戶端通過HTTP協議訪問服務器時,HTTP請求頭中的所有信息都封裝在這個對象中,通過這個對象提供的方法,可以獲得客戶端請求的所有信息。
HttpSession 服務端的技術
服務器會為每一個用戶 創建一個獨立的HttpSession
HttpSession原理
當用戶第一次訪問Servlet時,服務器端會給用戶創建一個獨立的Session
并且生成一個SessionID
,這個SessionID在響應瀏覽器的時候會被裝進cookie中,從而被保存到瀏覽器中,當用戶再一次訪問Servlet時,請求中會攜帶著cookie中的SessionID去訪問,服務器會根據這個SessionID去查看是否有對應的Session
對象
有就拿出來使用;沒有就創建一個Session(相當于用戶第一次訪問);
域的范圍:
Context域 > Session域 > Request域
Session域 只要會話不結束就會存在 但是Session有默認的存活時間(30分鐘)
Cookie
客戶端會話技術,將數據保存到客戶端
使用快速入門:
創建Cookie對象,綁定數據
new Cooike(String name,String value)
3.發送Cookie對象
response.addCookie(Cookie cookie)
4.獲取Cookie,拿到數據
Cookie[] request.getCookie()
Cookie銷毀時機
1.默認情況隨瀏覽器關閉被銷毀
2.手動設置情況下,設置Cookie存活時間,關閉瀏覽器不會導致Cookie被刪除;
cookie.setMaxAge(60);//設置cookie在硬盤存活1分鐘
Session
服務器端會話技術
對于Servlet而言:
若Servlet是客戶端訪問的第一個WEB應用的資源,則只有調用了request.getSession()或request.getSession(true) 才會創建HttpSession對象
1). 在Servlet中如何獲取HttpSession對象?
request.getSession(boolean create)
:create為false,若沒有和當前JSP頁面關聯的HttpSession對象,則返回null;
若有返回true create為true一定返回一個HTTPSession對象。若沒有和昂前JSP頁面關聯的HttpSession對象,則服務器創建一個新的HttpSession對象返回,若有,則直接返回關聯。
request.getSession()
等同于request.getSession(true)
2. 什么時候銷毀HttpSession對象:
1).直接調用HttpSession的invalidate()方法:使HttpSession失效
2).服務器卸載了當前Web應用。
3).超出HttpSession的過期時間。
設置HttpSession的過期時間:單位為S
session.setMaxInactiveInterval(5); out.print(session.getMaxInactiveInterval()); <!--在web.xml文件中設置HttpSession過期時間。 --> <session-config> <session-timeout>30</session-timeout> </session-config> <!--系統默認30分鐘 -->
這個時間就是Session的超時時間。如果超過了超時時間沒訪問過服務器,Session就自動失效了。
Session具有以下特點:
(1)Session中的數據保存在服務器端;
(2)Session中可以保存任意類型的數據;
(3)Session默認的生命周期是30分鐘,可以手動設置更長或更短的時間。
關于“Servlet怎么實現共享數據JavaWeb組件”這篇文章的內容就介紹到這里,感謝各位的閱讀!相信大家對“Servlet怎么實現共享數據JavaWeb組件”知識都有一定的了解,大家如果還想學習更多知識,歡迎關注億速云行業資訊頻道。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。