浅谈Listener、Filter、Servlet初始化顺序
创始人
2024-07-24 00:10:27
0

Listener、Filter、Servlet都有一个初始化的过程,对应的方法分别为:

contextInitialized(ServletContextEvent arg0)

init(FilterConfig filterConfig)

init(ServletConfig config)

那么它们的初始化顺序是什么呢?

Listener > Filter > Servlet

TestServlet.java

Java代码

  1. package com.cos;     
  2. import java.io.IOException;     
  3. import javax.servlet.GenericServlet;     
  4. import javax.servlet.ServletConfig;     
  5. import javax.servlet.ServletException;     
  6. import javax.servlet.ServletRequest;     
  7. import javax.servlet.ServletResponse;     
  8.     
  9. public class TestServlet extends GenericServlet {     
  10.     @Override    
  11.     public void init(ServletConfig config){     
  12.         System.out.println("Servlet 初始化 。。。");     
  13.     }     
  14.     @Override    
  15.     public void service(ServletRequest arg0, ServletResponse arg1) throws ServletException, IOException {     
  16.         System.out.println("Servlet service 。。。");     
  17.     }     
  18. }    

 

TestFilter.java

Java代码

  1. package com.cos;     
  2. import java.io.IOException;     
  3. import javax.servlet.Filter;     
  4. import javax.servlet.FilterChain;     
  5. import javax.servlet.FilterConfig;     
  6. import javax.servlet.ServletException;     
  7. import javax.servlet.ServletRequest;     
  8. import javax.servlet.ServletResponse;     
  9.     
  10. public class TestFilter implements Filter{     
  11.     public void init(FilterConfig filterConfig) throws ServletException {     
  12.         System.out.println("Filter 初始化。。。");     
  13.     }     
  14.     public void doFilter(ServletRequest request, ServletResponse response, FilterChain chain) throws IOException, ServletException {     
  15.         System.out.println("doFilter 。。。");     
  16.         chain.doFilter(request, response);     
  17.     }     
  18.     public void destroy() {     
  19.         System.out.println("Filter 销毁。。。");     
  20.     }     
  21. }   

 

TestListener.java

Java代码

  1. package com.cos;     
  2. import javax.servlet.ServletContextEvent;     
  3. import javax.servlet.ServletContextListener;     
  4.     
  5. public class TestListener implements ServletContextListener{     
  6.     public void contextInitialized(ServletContextEvent arg0) {     
  7.         System.out.println("Listener 初始化。。。");     
  8.     }     
  9.     public void contextDestroyed(ServletContextEvent arg0) {     
  10.         System.out.println("Listener 销毁。。。");     
  11.     }     
  12. }  

 

web.xml

Xml代码

  1.     
  2.     
  3.         
  4.         sservlet-name>    
  5.         com.cos.TestServletservlet-class>    
  6.     servlet>    
  7.         
  8.         sservlet-name>    
  9.         /loginurl-pattern>    
  10.     servlet-mapping>    
  11.         
  12.         ffilter-name>    
  13.         com.cos.TestFilterfilter-class>    
  14.     filter>    
  15.         
  16.         ffilter-name>    
  17.         /*url-pattern>    
  18.     filter-mapping>    
  19.         
  20.         com.cos.TestListenerlistener-class>    
  21.     listener>    
  22. web-app>    

 

 

 

启动tomcat后,在控制台里以此打印出:

Listener 初始化。。。

Filter 初始化。。。

信息: Server startup in 675 ms

可以看出Listener的初始化最早,Filter次之。他俩的初始化都是在容器启动完成之前初始化的。

Servlet没有初始化,原因是没有匹配的请求进来。

初始化的顺序跟Listener、Filter、Servlet在web.xml中的顺序无关

而多个Filter或多个Servlet的时候,谁的mapping在前面,谁先初始化。

【编辑推荐】

  1. 20个开发人员非常有用的Java功能代码
  2. 走进Java 7中的模块系统
  3. JavaFX 1.2 已经发布 主要新功能一览
  4. 2009年十大Java技术解决方案
  5. 2008最值得学习的五种JAVA技术

相关内容

热门资讯

如何允许远程连接到MySQL数... [[277004]]【51CTO.com快译】默认情况下,MySQL服务器仅侦听来自localhos...
如何利用交换机和端口设置来管理... 在网络管理中,总是有些人让管理员头疼。下面我们就将介绍一下一个网管员利用交换机以及端口设置等来进行D...
施耐德电气数据中心整体解决方案... 近日,全球能效管理专家施耐德电气正式启动大型体验活动“能效中国行——2012卡车巡展”,作为该活动的...
20个非常棒的扁平设计免费资源 Apple设备的平面图标PSD免费平板UI 平板UI套件24平图标Freen平板UI套件PSD径向平...
德国电信门户网站可实时显示全球... 德国电信周三推出一个门户网站,直观地实时提供其安装在全球各地的传感器网络检测到的网络攻击状况。该网站...
为啥国人偏爱 Mybatis,... 关于 SQL 和 ORM 的争论,永远都不会终止,我也一直在思考这个问题。昨天又跟群里的小伙伴进行...
《非诚勿扰》红人闫凤娇被曝厕所... 【51CTO.com 综合消息360安全专家提醒说,“闫凤娇”、“非诚勿扰”已经被黑客盯上成为了“木...
2012年第四季度互联网状况报... [[71653]]  北京时间4月25日消息,据国外媒体报道,全球知名的云平台公司Akamai Te...