淺談Listener、Filter、Servlet初始化順序
Listener、Filter、Servlet都有一個(gè)初始化的過程,對(duì)應(yīng)的方法分別為:
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 。。。");
- }
- }
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 銷毀。。。");
- }
- }
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 銷毀。。。");
- }
- }
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>s< span>servlet-name>
- <servlet-class>com.cos.TestServlet< span>servlet-class>
- < span>servlet>
- <servlet-mapping>
- <servlet-name>s< span>servlet-name>
- <url-pattern>/login< span>url-pattern>
- < span>servlet-mapping>
- <filter>
- <filter-name>f< span>filter-name>
- <filter-class>com.cos.TestFilter< span>filter-class>
- < span>filter>
- <filter-mapping>
- <filter-name>f< span>filter-name>
- <url-pattern>/*< span>url-pattern>
- < span>filter-mapping>
- <listener>
- <listener-class>com.cos.TestListener< span>listener-class>
- < span>listener>
- < span>web-app>
啟動(dòng)tomcat后,在控制臺(tái)里以此打印出:
Listener 初始化。。。
Filter 初始化。。。
信息: Server startup in 675 ms
可以看出Listener的初始化最早,F(xiàn)ilter次之。他倆的初始化都是在容器啟動(dòng)完成之前初始化的。
Servlet沒有初始化,原因是沒有匹配的請(qǐng)求進(jìn)來。
初始化的順序跟Listener、Filter、Servlet在web.xml中的順序無關(guān)
而多個(gè)Filter或多個(gè)Servlet的時(shí)候,誰的mapping在前面,誰先初始化。
【編輯推薦】