浅谈Listener、Filter、Servlet初始化顺序

开发 后端
本篇文章主要讲Listener、Filter、Servlet的初始化过程,希望对大家有所帮助。

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

contextInitialized(ServletContextEvent arg0)

init(FilterConfig filterConfig)

init(ServletConfig config)

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

Listener > Filter > Servlet

TestServlet.java

Java代码

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

 

TestFilter.java

Java代码

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

 

TestListener.java

Java代码

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

 

web.xml

Xml代码

xml version="1.0" encoding="UTF-8"?>    
<web-app version="2.5" xmlns="http://java.sun.com/xml/ns/javaee" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://java.sun.com/xml/ns/javaee http://java.sun.com/xml/ns/javaee/web-app_2_5.xsd">    
    <servlet>    
        <servlet-name>sservlet-name>    
        <servlet-class>com.cos.TestServletservlet-class>    
    servlet>    
    <servlet-mapping>    
        <servlet-name>sservlet-name>    
        <url-pattern>/loginurl-pattern>    
    servlet-mapping>    
    <filter>    
        <filter-name>ffilter-name>    
        <filter-class>com.cos.TestFilterfilter-class>    
    filter>    
    <filter-mapping>    
        <filter-name>ffilter-name>    
        <url-pattern>/*url-pattern>    
    filter-mapping>    
    <listener>    
        <listener-class>com.cos.TestListenerlistener-class>    
    listener>    
web-app>    
  • 1.
  • 2.
  • 3.
  • 4.
  • 5.
  • 6.
  • 7.
  • 8.
  • 9.
  • 10.
  • 11.
  • 12.
  • 13.
  • 14.
  • 15.
  • 16.
  • 17.
  • 18.
  • 19.
  • 20.
  • 21.
  • 22.

 

 

 

启动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技术
责任编辑:金贺 来源: JavaEye博客
相关推荐

2009-09-08 09:48:34

LINQ初始化数组

2010-07-28 10:22:33

FlexApplica

2009-07-31 17:51:27

C#对象初始化

2009-06-10 16:17:00

Netbeans JT初始化

2009-08-26 15:28:52

C#对象集合初始化器

2012-02-28 10:04:09

Java

2009-10-20 14:03:48

VB.NET数组声明VB.NET数组初始化

2011-08-10 13:36:30

Servlet

2013-03-04 11:10:03

JavaJVM

2023-11-12 23:08:17

C++初始化

2009-07-03 16:21:33

Java的声明和初始化Java

2022-01-04 19:33:03

Java构造器调用

2009-11-11 15:29:15

ADO初始化

2019-11-04 13:50:36

Java数组编程语言

2011-06-17 15:29:44

C#对象初始化器集合初始化器

2022-07-06 10:37:45

SpringServlet初始化

2021-03-12 10:30:11

SpringMVC流程初始化

2020-12-03 09:50:52

容器IoC流程

2024-01-15 06:34:09

Gin镜像容器

2009-12-16 14:04:04

Ruby对象初始化
点赞
收藏

51CTO技术栈公众号