Servlet方法生命周期及執(zhí)行原理詳解
快速入門
創(chuàng)建JavaEE項(xiàng)目
定義一個(gè)類,實(shí)現(xiàn)Servlet接口
public class ServletDemo1 implements Servlet {
/**
* 初始化方法
* 在Servlet被創(chuàng)建時(shí),執(zhí)行。只會執(zhí)行一次
* @param servletConfig
* @throws ServletException
* */
@Override
public void init(ServletConfig servletConfig) throws ServletException {
System.out.println("init......");
}
/**
* 獲取ServletConfig對象
* ServletCongig:Servlet的配置對象
* @return
* */
@Override
public ServletConfig getServletConfig() {
return null;
}
/**
* 提供服務(wù)方法
* 每一次Servlet被訪問時(shí),執(zhí)行。可執(zhí)行多次
* @param servletRequest
* @param servletResponse
* @throws ServletException
* @throws IOException
* */
@Override
public void service(ServletRequest servletRequest, ServletResponse servletResponse) throws ServletException, IOException {
System.out.println("服務(wù)小皮皮美滋滋!");
}
/**
* 獲取Servlet的一些詳細(xì),版本,作者等等
* @return
* */
@Override
public String getServletInfo() {
return null;
}
/**
* 銷毀方法
* 在服務(wù)器正常關(guān)閉時(shí)執(zhí)行。執(zhí)行一次
* */
@Override
public void destroy() {
System.out.println("服務(wù)關(guān)閉了...");
}
}
實(shí)現(xiàn)接口中的抽象方法
配置Servlet
在web.xml中配置
<!--配置Servlet -->
<servlet>
<servlet-name>demo1</servlet-name>
<servlet-class>xppmzz.ServletDemo1</servlet-class>
</servlet>
<servlet-mapping>
<servlet-name>demo1</servlet-name>
<url-pattern>/demo1</url-pattern>
</servlet-mapping>
執(zhí)行
點(diǎn)擊IDEA中Tomcat的啟動(dòng)按鈕,在瀏覽器中輸入http://localhost:8080/demo1。
觀察IDEA輸出窗口輸出內(nèi)容。
執(zhí)行原理

- 當(dāng)服務(wù)器接受到客戶端瀏覽器的請求后,會解析請求
URL路徑,獲取訪問的Servlet的資源路徑。 - 查找
web.xml文件,是否有對應(yīng)的<url-pattern>標(biāo)簽體內(nèi)容。 - 如果有,則在找到對應(yīng)的
<servlet-class>全類名。 tomcat會將字節(jié)碼文件加載進(jìn)內(nèi)存,并且創(chuàng)建其對象。- 調(diào)用其方法。
Servlet中的生命周期方法
1.被創(chuàng)建:執(zhí)行init方法,只執(zhí)行一次
- Servlet什么時(shí)候被創(chuàng)建?
默認(rèn)情況下,第一次被訪問時(shí),Servlet被創(chuàng)建。
- 可以配置執(zhí)行Servlet的創(chuàng)建時(shí)機(jī)。
在<servlet>標(biāo)簽下配置:
第一次被訪問時(shí),創(chuàng)建<load-on-startup>的值為負(fù)數(shù)。
在服務(wù)器啟動(dòng)時(shí),創(chuàng)建<load-on-startup>的值為0或正整數(shù)。
<servlet>
<servlet-name>demo1</servlet-name>
<servlet-class>xppmzz.ServletDemo1</servlet-class>
<load-on-startup>5</load-on-startup>
</servlet>
如果為負(fù)數(shù),則在瀏覽器中第一次輸入http://localhost:8080/demo1才會執(zhí)行init方法。0或者正整數(shù)會在Tomcat第一次啟動(dòng)時(shí)執(zhí)行init方法。
- Servlet的init方法,只執(zhí)行一次,說明一個(gè)Servlet在內(nèi)存中只存在一個(gè)對象,Servlet是單例的。
因此,多個(gè)用戶同時(shí)訪問時(shí),可能存在線程安全問題。
解決:盡量不要在Servlet中定義成員變量。即使定義了成員變量,也不要對修改值
2.提供服務(wù):執(zhí)行service方法,執(zhí)行多次
每次訪問Servlet時(shí),Service方法都會被調(diào)用一次。
3.被銷毀:執(zhí)行destroy方法,只執(zhí)行一次
- Servlet被銷毀時(shí)執(zhí)行。服務(wù)器關(guān)閉時(shí),Servlet被銷毀。
- 只有服務(wù)器正常關(guān)閉時(shí),才會執(zhí)行destroy方法。
- destroy方法在Servlet被銷毀之前執(zhí)行,一般用于釋放資源。
Servlet3.0
好處:支持注解配置,可以不需要web.xml。
步驟:
創(chuàng)建JavaEE項(xiàng)目,選擇Servlet的版本3.0以上,可以不創(chuàng)建web.xml。
定義一個(gè)類,實(shí)現(xiàn)Servlet接口。
復(fù)寫方法。
在類上使用@WebServlet注解,進(jìn)行配置。@WebServlet("資源路徑")
代碼示例:
@Target({ElementType.TYPE})
@Retention(RetentionPolicy.RUNTIME)
@Documented
public @interface WebServlet {
String name() default "";//相當(dāng)于<Servlet-name>
String[] value() default {};//代表urlPatterns()屬性配置
String[] urlPatterns() default {};//相當(dāng)于<url-pattern>
int loadOnStartup() default -1;//相當(dāng)于<load-on-startup>
WebInitParam[] initParams() default {};
boolean asyncSupported() default false;
String smallIcon() default "";
String largeIcon() default "";
String description() default "";
String displayName() default "";
}
Servlet體系結(jié)構(gòu)
Servlet – 接口
GenericServlet – 抽象類
HttpServlet – 抽象類
GenericServlet
將Servlet接口中其他的方法做了默認(rèn)空實(shí)現(xiàn),只將service()方法作為抽象。
將來定義Servlet類時(shí),可以繼承GenericServlet,實(shí)現(xiàn)service()方法即可
@WebServlet("/demo2")
public class ServletDemo2 extends GenericServlet {
@Override
public void service(ServletRequest servletRequest, ServletResponse servletResponse) throws ServletException, IOException {
System.out.println("GenericServlet....");
}
}
HttpServlet
對http協(xié)議的一種封裝,簡化操作。
定義類繼承HttpServlet。
復(fù)寫doGet/doPost方法。
@WebServlet("/demo3")
public class ServletDemo3 extends HttpServlet {
@Override
protected void doGet(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
System.out.println("doGet......");
}
@Override
protected void doPost(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
System.out.println("doPost......");
}
}
Servlet相關(guān)配置
urlpartten:Servlet訪問路徑。
一個(gè)Servlet可以定義多個(gè)訪問路徑 : @WebServlet({"/d4","/dd4","/ddd4"})路徑定義規(guī)則:/xxx:路徑匹配。/xxx/xxx:多層路徑,目錄結(jié)構(gòu)。*.do:擴(kuò)展名匹配。
以上就是Servlet方法生命周期及執(zhí)行原理詳解的詳細(xì)內(nèi)容,更多關(guān)于Servlet的資料請關(guān)注腳本之家其它相關(guān)文章!
相關(guān)文章
PowerJob LockService方法工作流程源碼解讀
這篇文章主要為大家介紹了PowerJob LockService方法工作流程源碼解讀,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2024-01-01
SpringBoot停止啟動(dòng)時(shí)測試檢查rabbitmq操作
這篇文章主要介紹了SpringBoot停止啟動(dòng)時(shí)測試檢查rabbitmq操作,具有很好的參考價(jià)值,希望對大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2021-09-09
eclipse實(shí)現(xiàn)可認(rèn)證的DH密鑰交換協(xié)議
這篇文章主要介紹了eclipse實(shí)現(xiàn)可認(rèn)證的DH密鑰交換協(xié)議,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2020-06-06
數(shù)據(jù)結(jié)構(gòu)與算法之手撕排序算法
排序算法看似簡單,其實(shí)不同的算法中蘊(yùn)涵著經(jīng)典的算法策略。通過熟練掌握排序算法,就可以掌握基本的算法設(shè)計(jì)思想,本文主要介紹了Java中的排序算法,需要的朋友歡迎閱讀2023-04-04

