淺談Listener、Filter、Servlet初始化順序
Listener、Filter、Servlet都有一個初始化的過程,對應的方法分別為:
contextInitialized(ServletContextEvent arg0); // Listener init(FilterConfig filterConfig); // Filter init(ServletConfig config); // Servlet
那么它們的初始化順序是什么呢?
Listener > Filter > Servlet
TestServlet.java:
package com.king;
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:
package com.king;
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:
package com.king;
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 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<servlet-name>
<servlet-class>com.cos.TestServlet<servlet-class>
<servlet>
<servlet-mapping>
<servlet-name>s<servlet-name>
<url-pattern>/login<url-pattern>
<servlet-mapping>
<filter>
<filter-name>f<filter-name>
<filter-class>com.cos.TestFilter<filter-class>
<filter>
<filter-mapping>
<filter-name>f<filter-name>
<url-pattern>/*<url-pattern>
<filter-mapping>
<listener>
<listener-class>com.cos.TestListener<listener-class>
<listener>
<web-app> 啟動tomcat后,在控制臺里以此打印出:
Listener 初始化。。。
Filter 初始化。。。
信息: Server startup in 675 ms
可以看出Listener的初始化最早,Filter次之。他倆的初始化都是在容器啟動完成之前初始化的。Servlet沒有初始化,原因是沒有匹配的請求進來。初始化的順序跟Listener、Filter、Servlet在web.xml中的順序無關。
而多個Filter或多個Servlet的時候,誰的mapping在前面,誰先初始化。
本文由用戶 likeo 自行上傳分享,僅供網友學習交流。所有權歸原作者,若您的權利被侵害,請聯系管理員。
轉載本站原創文章,請注明出處,并保留原始鏈接、圖片水印。
本站是一個以用戶分享為主的開源技術平臺,歡迎各類分享!