您好,登錄后才能下訂單哦!
本篇內容介紹了“有關Servlet的知識點總結”的有關知識,在實際案例的操作過程中,不少人都會遇到這樣的困境,接下來就讓小編帶領大家學習一下如何處理這些情況吧!希望大家仔細閱讀,能夠學有所成!
1. 概述
在這篇簡短的文章中,我們將從概念上理解什么是servlet 和 servlet 容器以及它們是如何工作的。同時,還能在請求、響應、會話對象、共享變量和多線程的上下文中看到它們的身影。
2. Servlets 和 它的容器
servlet 是 JEE 用于 web 開發常用的組件。它們基本上是運行在容器邊界內的Java程序。總的來說,它們負責接受請求,處理請求,并返回響應。
要使用它們,首先需要容器注冊 servlet ,無論是基于 JEE 還是基于 Spring 的容器,都可以在啟動時接收它們。在開始時,容器通過調用 init() 方法來實例化 servlet。初始化完成后,servlet 就可以接受傳入的請求。隨后,容器將這些請求定向到 servlet 的 service 方法中進行處理。之后,它根據HTTP請求類型將請求進一步委托給適當的方法,例如 doGet() 或 doPost() 。
使用 destroy(),容器會銷毀 servlet,并且不再接受傳入的請求。我們將這個 init-service-destroy 的循環稱為 servlet 的生命周期。
現在我們從容器的角度來看,比如 Apache Tomcat 或 Jetty 在啟動時,創建一個 ServletContext 的對象,ServletContext 的任務是充當服務器或容器的內存,并記住與web應用程序相關聯的所有servlet、過濾器和偵聽器,如其 web.xml文件或等效注解。在容器停止之前,ServletContext 會一直保留它。
不管怎么說,servlet的 load-on-startup 參數扮演重要的角色 。如果此參數的值大于零,則只有在啟動時服務器才會對其進行初始化。如果未指定此參數,則在請求第一次命中 servlet時調用它的 init()。
3. Request, Response 和 Session
在上一節中,我們討論了發送請求和接收響應,這基本上是任何CS應用程序的基礎。現在,我們從servlet的角度來詳細了解它們。
在這種情況下,請求將由 HttpServletRequest 表示,響應將用 HttpServletResponse 表示。
每當瀏覽器或curl命令等發送請求時,容器都會創建一個新的 HttpServletRequest 和 HttpServletResponse 對象。然后將這些新對象傳遞給 servlet 的 service方法。基于 HttpServletRequest 的 method 屬性,此方法確定應調用哪個 doXXX方法。
除了有關方法的信息外,request對象還攜帶其他信息,如頭、參數和主體。類似地,HttpServletResponse對象也攜帶頭、參數和主體——我們可以在 servlet 的 doXXX 方法中設置它們。
這些對象的生命稍縱即逝。當客戶端獲得響應時,服務器將標記用于垃圾回收的請求和響應對象。那么我們如何在隨后的客戶端請求或連接之間保持一個狀態?答案就是 HttpSession。
原理是將這些對象綁定到用戶會話,以便與特定用戶相關的信息可以跨多個請求持久化。這通常是通過使用cookies的概念,使用 [JSESSIONID] 作為給定會話的唯一標識符。我們可以在web.xml中指定會話的超時時長。
<session-config> <session-timeout>10</session-timeout> </session-config>
以上配置表示,如果會話空閑了10分鐘,服務器將丟棄它。任何后續請求都將創建一個新的會話。
4. Servlets 共享數據
根據所需的范圍,servlet 可以通過多種方式共享數據。
正如在前面的章節中提到的,不同的對象有不同的生命周期。HttpServletRequest和HttpServletResponse 對象只存在于一個 servlet 調用之間。HttpSession只要它處于活動狀態并且沒有超時,它就會一直存在。
ServletContext的生命周期最長。它與Web應用程序一起誕生,只有當應用程序本身關閉時才會被銷毀。由于servlet、filter 和 listener 實例與上下文綁定,所以只要web應用程序啟動并運行,它們也會一直存在。
因此,如果我們的需求是在所有servlet之間共享數據,假設我們要計算站點的訪問者數量,那么我們應該將變量放在 ServletContext 中。如果我們需要在一個會話中共享數據,那么我們就把它保存在會話范圍內。在本例中,用戶名就是一個例子。
最后,還有與單個請求的數據相關的請求范圍,比如請求有效負載。
5. 處理多線程
多個HttpServletRequest 對象彼此共享 servlet,這樣每個請求都使用它自己的 servlet 實例線程進行操作。
就線程安全而言,這實際上表明:我們不應該將請求或會話范圍內的數據指定為 servlet的實例變量。
例如,下面的代碼片段:
public class ExampleThree extends HttpServlet { private String instanceMessage; @Override protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException { String message = request.getParameter("message"); instanceMessage = request.getParameter("message"); request.setAttribute("text", message); request.setAttribute("unsafeText", instanceMessage); request.getRequestDispatcher("/jsp/ExampleThree.jsp").forward(request, response); } }
在本例中,會話中的所有請求共享 instanceMessage,而 message對于給定的請求對象是唯一的。因此,在并發請求的情況下,instanceMessage 中的數據可能不一致。
“有關Servlet的知識點總結”的內容就介紹到這里了,感謝大家的閱讀。如果想了解更多行業相關的知識可以關注億速云網站,小編將為大家輸出更多高質量的實用文章!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。