首先可以确定的一点是, 不同类型节点的加载顺序与它们在web.xml里出现的次序无关,即不会因为filter写在listener之前而先加载fiter.
就<context-param>、<listener>、<filter>、<servlet>四种节点而言,启动服务器时的加载顺序是context-param --> listener --> filter --> servlet
首先是<context-param>,启动一个WEB项目的时候,WEB容器会读取配置描述符文件(web.xml)中的<context-param>节点信息。<context-param>它用于向 ServletContext 提供键值对,即应用程序上下文信息。在初始化listener, filter和servlet时到可能会用到这些信息。
例如在监听器(listener)中有一个contextInitialized(ServletContextEvent contextEvent)初始化方法,在这个方法中可以通过 contextEvent .getServletContext() 可以获得ServletContext对象,然后再从ServletContext中通过getInitParameter(String)方法获取<context-param>的键值:
ServletContext servletContext = contextEvent.getServletContext(); Object context-param的值 = servletContext .getInitParameter("context-param的键");
<context-param>包含两个子元素,分别是<param-name>和<param-value>。 前者用来设置context的名字,后者用来设置其值。
当param-value有多个值时, 用逗号隔开。 <param-value>里也可以使用通配符,比如:
contextConfigLocation classpath*:/applicationContext.xml,classpath*:/applicationContext-security.xml
接着初始化listener, 主要子元素为< listener-class>,如:
org.springframework.web.context.ContextLoaderListener
然后是filter。 filter元素主要包括<filter-name>,<filter-class>和<init-param>, 一个典型的<filter>节点声明如下:
Cache Filter - Friendly com.liferay.portal.servlet.filters.cache.CacheFilter pattern 0
filter-mapping用来定义filter所对应的url匹配模式,它有两个子元素,分别是<filter-name>和<url-pattern>,一个典型的<filter-mapping>节点如下:
Cache Filter - Layout /c/portal/layout
注意: 对于同一类型的配置节而言,与它们出现的顺序是有关的。以<filter>为例,web.xml中当然可以定义多个<filter>,与<filter>相关的一个配置节是<filter-mapping>,这里一定要注意,对于拥有相同<filter-name>的<filter>和<filter-mapping>配置节而言,<filter-mapping>必须出现在<filter>之后,否则当解析到<filter-mapping>时,它所对应的<filter-name>还未定义。web 容器启动时初始化每个<filter>时,是按照<filter>配置节出现的顺序来初始化的,当请求资源匹配多个<filter-mapping>时,<filter>拦截资源是按照<filter-mapping>配置节出现的顺序来依次调用doFilter() 方法的。
最后初始化servlet。和filter一样,servlet也分<servlet>和<servlet-mapping>两部分声明。一个典型的servlet声明如下:
Friendly URL Servlet - Private User com.liferay.portal.servlet.FriendlyURLServlet user true 2 Friendly URL Servlet - Private User /user/*
其中的<load-on-startup>值为正数或零时:Servlet容器先加载数值小的servlet,再依次加载其他数值大的servlet. 当值为负或未定义:Servlet容器将在Web客户首次访问这个servlet时加载它.