Servlet方法生命周期及執(zhí)行原理詳解
快速入門(mén)
創(chuàng)建JavaEE項(xiàng)目
定義一個(gè)類(lèi),實(shí)現(xiàn)Servlet接口
public class ServletDemo1 implements Servlet {
/**
* 初始化方法
* 在Servlet被創(chuàng)建時(shí),執(zhí)行。只會(huì)執(zhí)行一次
* @param servletConfig
* @throws ServletException
* */
@Override
public void init(ServletConfig servletConfig) throws ServletException {
System.out.println("init......");
}
/**
* 獲取ServletConfig對(duì)象
* ServletCongig:Servlet的配置對(duì)象
* @return
* */
@Override
public ServletConfig getServletConfig() {
return null;
}
/**
* 提供服務(wù)方法
* 每一次Servlet被訪(fǎng)問(wèn)時(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;
}
/**
* 銷(xiāo)毀方法
* 在服務(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。
觀(guān)察IDEA輸出窗口輸出內(nèi)容。
執(zhí)行原理

- 當(dāng)服務(wù)器接受到客戶(hù)端瀏覽器的請(qǐng)求后,會(huì)解析請(qǐng)求
URL路徑,獲取訪(fǎng)問(wèn)的Servlet的資源路徑。 - 查找
web.xml文件,是否有對(duì)應(yīng)的<url-pattern>標(biāo)簽體內(nèi)容。 - 如果有,則在找到對(duì)應(yīng)的
<servlet-class>全類(lèi)名。 tomcat會(huì)將字節(jié)碼文件加載進(jìn)內(nèi)存,并且創(chuàng)建其對(duì)象。- 調(diào)用其方法。
Servlet中的生命周期方法
1.被創(chuàng)建:執(zhí)行init方法,只執(zhí)行一次
- Servlet什么時(shí)候被創(chuàng)建?
默認(rèn)情況下,第一次被訪(fǎng)問(wèn)時(shí),Servlet被創(chuàng)建。
- 可以配置執(zhí)行Servlet的創(chuàng)建時(shí)機(jī)。
在<servlet>標(biāo)簽下配置:
第一次被訪(fǎng)問(wèn)時(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才會(huì)執(zhí)行init方法。0或者正整數(shù)會(huì)在Tomcat第一次啟動(dòng)時(shí)執(zhí)行init方法。
- Servlet的init方法,只執(zhí)行一次,說(shuō)明一個(gè)Servlet在內(nèi)存中只存在一個(gè)對(duì)象,Servlet是單例的。
因此,多個(gè)用戶(hù)同時(shí)訪(fǎng)問(wèn)時(shí),可能存在線(xiàn)程安全問(wèn)題。
解決:盡量不要在Servlet中定義成員變量。即使定義了成員變量,也不要對(duì)修改值
2.提供服務(wù):執(zhí)行service方法,執(zhí)行多次
每次訪(fǎng)問(wèn)Servlet時(shí),Service方法都會(huì)被調(diào)用一次。
3.被銷(xiāo)毀:執(zhí)行destroy方法,只執(zhí)行一次
- Servlet被銷(xiāo)毀時(shí)執(zhí)行。服務(wù)器關(guān)閉時(shí),Servlet被銷(xiāo)毀。
- 只有服務(wù)器正常關(guān)閉時(shí),才會(huì)執(zhí)行destroy方法。
- destroy方法在Servlet被銷(xiāo)毀之前執(zhí)行,一般用于釋放資源。
Servlet3.0
好處:支持注解配置,可以不需要web.xml。
步驟:
創(chuàng)建JavaEE項(xiàng)目,選擇Servlet的版本3.0以上,可以不創(chuàng)建web.xml。
定義一個(gè)類(lèi),實(shí)現(xiàn)Servlet接口。
復(fù)寫(xiě)方法。
在類(lèi)上使用@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 – 抽象類(lèi)
HttpServlet – 抽象類(lèi)
GenericServlet
將Servlet接口中其他的方法做了默認(rèn)空實(shí)現(xiàn),只將service()方法作為抽象。
將來(lái)定義Servlet類(lèi)時(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
對(duì)http協(xié)議的一種封裝,簡(jiǎn)化操作。
定義類(lèi)繼承HttpServlet。
復(fù)寫(xiě)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訪(fǎng)問(wèn)路徑。
一個(gè)Servlet可以定義多個(gè)訪(fǎng)問(wèn)路徑 : @WebServlet({"/d4","/dd4","/ddd4"})路徑定義規(guī)則:/xxx:路徑匹配。/xxx/xxx:多層路徑,目錄結(jié)構(gòu)。*.do:擴(kuò)展名匹配。
以上就是Servlet方法生命周期及執(zhí)行原理詳解的詳細(xì)內(nèi)容,更多關(guān)于Servlet的資料請(qǐng)關(guān)注腳本之家其它相關(guān)文章!
相關(guān)文章
SpringCloud GateWay動(dòng)態(tài)路由用法
網(wǎng)關(guān)作為所有項(xiàng)目的入口,不希望重啟,因此動(dòng)態(tài)路由是必須的,動(dòng)態(tài)路由主要通過(guò)RouteDefinitionRepository接口實(shí)現(xiàn),其默認(rèn)的實(shí)現(xiàn)是InMemoryRouteDefinitionRepository,即在內(nèi)存中存儲(chǔ)路由配置,可基于這個(gè)map對(duì)象操作,動(dòng)態(tài)路由的實(shí)現(xiàn)方案有兩種2024-10-10
java實(shí)現(xiàn)簡(jiǎn)單點(diǎn)贊功能
這篇文章主要為大家詳細(xì)介紹了java實(shí)現(xiàn)簡(jiǎn)單點(diǎn)贊功能,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2022-08-08
java8 stream 由一個(gè)list轉(zhuǎn)化成另一個(gè)list案例
這篇文章主要介紹了java8 stream 由一個(gè)list轉(zhuǎn)化成另一個(gè)list案例,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2020-08-08
Java對(duì)線(xiàn)程池做監(jiān)控的實(shí)現(xiàn)方法
本文主要介紹了Java對(duì)線(xiàn)程池做監(jiān)控的實(shí)現(xiàn)方法,監(jiān)控線(xiàn)程池可以幫助我們了解線(xiàn)程池的狀態(tài),如當(dāng)前活躍線(xiàn)程數(shù)、任務(wù)隊(duì)列長(zhǎng)度、已完成任務(wù)數(shù)等,下面就一起來(lái)了解一下2024-07-07
解決mybatis where-if中if不能識(shí)別大寫(xiě)AND,OR的問(wèn)題
這篇文章主要介紹了解決mybatis where-if中if不能識(shí)別大寫(xiě)AND,OR的問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2021-02-02
Java中將MultipartFile和File互轉(zhuǎn)的方法詳解
我們?cè)陂_(kāi)發(fā)過(guò)程中經(jīng)常需要接收前端傳來(lái)的文件,通常需要處理MultipartFile格式的文件,今天來(lái)介紹一下MultipartFile和File怎么進(jìn)行優(yōu)雅的互轉(zhuǎn),需要的朋友可以參考下2023-10-10
聊聊@RequestBody和Json之間的關(guān)系
這篇文章主要介紹了@RequestBody和Json之間的關(guān)系,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2021-06-06

