在JavaWeb中有三大組件,分別是Servlet、Filter和Listener。其中Servlet的作用是處理請求,服務器會把接收到的請求交給Servlet來處理,即接收請求數據、處理請求和完成響應。
1. 實現Servlet的方式
主要有三種實現方式:1)實現javax.servlet.Servlet接口;2)繼承javax.servlet.GenericServlet類;3)繼承javax.servlet.http.HttpServlet類;其中最常用的繼承HttpServlet類來實現。
2. 關于Servlet接口
public interface Servlet {
public void init(ServletConfig config) throws ServletException;
public ServletConfig getServletConfig();
public void service(ServletRequest req, ServletResponse res)
throws ServletException, IOException;
public String getServletInfo();
public void destroy();
}
如上是Servlet接口的源碼,內部主要有五個方法,其中與Servlet生命周期有關的方法有 init方法、service方法和destroy方法。
1) void init(ServletConfig);它會在Servlet對象創建之后馬上執行,并且只執行一次。
2) void service(ServletRequest,ServletResponse);它會被調用多次,每次處理請求都被調用。
3) void destroy();它會在Servlet被銷毀之前被Tomcat調用,并且只執行一次。
3. Servlet的創建
服務器會在Servlet第一次被訪問時創建Servlet,或者是在服務器啟動時創建Servlet。如果服務器啟動時就創建Servlet,那么還需要在web.xml文件中配置。如果 Servlet 的 load-on-startup 配置項大于 0,那么在 Context 容器啟動的時候就會被實例化,也就是說默認情況下,Servlet是在第一次被訪問時由服務器創建的。而且一個Servlet類型,服務器只創建一個實例對象。
4. Servlet與線程安全
因為一個類型的Servlet只有一個實例對象,那么就有可能會現時出一個Servlet同時處理多個請求,那么Servlet是否為線程安全的呢?答案是:“不是線程安全的”。這說明Servlet的工作效率很高,但也存在線程安全問題!
所以我們不應該在Servlet中隨便創建成員變量,因為可能會存在一個線程對這個成員變量進行寫操作,另一個線程對這個成員變量進行讀操作。
5. Servlet的使用
如果想要瀏覽器可以訪問Servlet,需要給Servlet綁定一個路徑,這個需要在web.xml中進行配置。其中<servlet> 指定HelloServlet這個Servlet的名稱為hello;<servlet-mapping>:指定/helloworld訪問路徑所以訪問的Servlet名為hello。<servlet>和<servlet-mapping>通過<servlet-name>這個元素關聯在一起。
<servlet> <servlet-name>hello</servlet-name> <servlet-class>com.Demrystv.HelloServlet</servlet-class> </servlet> <servlet-mapping> <servlet-name>hello</servlet-name> <url-pattern>/helloworld</url-pattern> </servlet-mapping>
6. 關于HttpServlet
HttpServlet類是GenericServlet的子類,它提供了對HTTP請求的特殊支持,所以通常我們都會通過繼承HttpServlet來完成自定義的Servlet。
HttpServlet類是一個抽象類,但是沒有抽象方法,必須繼承,實現doGet或者doPost,但是doGet()或doPost()方法不是抽象方法,默認的實現是給客戶一個405。
以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持億速云。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。