结论
先说结论,在JavaWeb的web.xml中的加载顺序为:
context-param -> listener -> filter -> servlet
分析
下面描述的是以运行在tomcat中的web程序为例,首先web程序会去读web.xml文件。
1、context-param
<context-param></context-param>
这个标签是web程序的上下文参数,也是启动的初始化参数,web程序最先解析的就是这个标签,无论这个标签在什么位置都先解析这个标签。解析上面的context-param标签之后会创建一个ServletContext对象,web项目的整个Application都将共享这个ServletContext。说到这里要注意一个问题,就是《Tomcat部署多工程时Log4j的问题》。
2、listener
<listener></listener>
这个标签是监听器,上面步骤完成之后tomcat会创建监听器的实例就是标签里面的对象。在监听中会有contextInitialized(ServletContextEvent args)
初始化方法,在这个方法中可以获得ServletContext对象,从而获取context-param的值
ServletContext = ServletContextEvent.getServletContext()
context-param = ServletContext.getInitParameter("context-param的key")
3、filter
<filter></filter>
这个是过滤器,完成上面步骤后开始实例化。注意:如果有多个过滤器,那就按照过滤器在web.xml的顺序来执行。
4、servlet
<servlet></servlet>
这个属于服务接口,这个是在以上都完成之后才开始实例化。
在servlet的配置当中,<load-on-startup>
的含义是:
- 零或者正数代表服务启动就启动该servlet;
- 正数的值越小,启动该servlet的优先级越高;
- 负值或者无此配置则使用时才会被执行。
总结
如果是在Springmvc或者Struct框架中会有interceptor拦截器
,如果是在框架中执行顺序如下:
context-param -> listener -> filter -> interceptor -> 控制器