Filter系列五 谈谈启动方面
来源:互联网 发布:北京网络微信投票公司 编辑:程序博客网 时间:2024/06/15 00:34
转自:http://tianhei.iteye.com/blog/970393
Listener、Filter、Servlet都有一个初始化的过程,对应的方法分别为:
contextInitialized(ServletContextEvent arg0)
init(FilterConfig filterConfig)
init(ServletConfig config)
那么它们的初始化顺序是什么呢?
Listener > Filter > Servlet
TestServlet.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 。。。");
- }
- }
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
- 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 销毁。。。");
- }
- }
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
- 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 销毁。。。");
- }
- }
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 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>
<?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没有初始化,原因是没有匹配的请求进来。
如果想要servlet自动初始化,需要在指定的servlet中配置<load-on-startup>参数,没有此标签,默认启动时servlet不进行初始化。
初始化的顺序跟Listener、Filter、Servlet在web.xml中的顺序无关
而多个Filter或多个Servlet的时候,谁的mapping在前面,谁先初始化。
如果web.xml中配置了<context-param>,初始化顺序:
context-param > Listener > Filter > Servlet
0 0
- Filter系列五 谈谈启动方面
- 【AOP系列】(五)—Filter
- 《windows核心编程系列》五谈谈线程基础
- 《windows核心编程系列》五谈谈线程基础
- 【工业4.0系列谈之五】建设智能工厂 可从这6个方面着手
- 谈谈五皇后问题
- S3C2416裸机开发系列五_Nand驱动以及Nand启动
- Storm系列(五)架构分析之Nimbus启动过程
- GD32F130FXP6学习笔记五:cortex-m3系列的启动过程
- 谈谈head first系列
- 谈谈面试--哈希表系列
- 谈谈我对bloom filter的理解。
- ---Filter ( 五 ) filter统一验证是否登录
- Filter系列一
- Filter系列二
- Filter系列三
- Filter系列四
- Filter(五)FilterChain执行顺序
- 有用的Web或者手机UI设计工具
- Openfire服务端源代码开发配置指南
- OCP 1Z0 053 32
- 神奇的图像处理算法
- java.lang.UnsupportedClassVersionError: Unsupported major.minor version 49.0的错误 [转]
- Filter系列五 谈谈启动方面
- 为了您心甘情愿-香味营销
- 简单python常用模块
- libgdx 动画
- 使用FileUpload接收上传内容
- LeetCode: Symmetric Tree
- Convert a given tree to its Sum Tree
- 理解OAuth 2.0
- com学习(四)——用 ATL 写第一个组件