`

web.xml 加载顺序(load-on-startup)

    博客分类:
  • web
 
阅读更多
web.xml 文件中一般包括 servlet, spring, filter, listenr的配置。那么他们是按照一个什么顺序加载呢?

加载顺序会影响对spring bean 的调用。

    比如filter 需要用到 bean ,但是加载顺序是 先加载filter 后加载spring,则filter中初始化操作中的bean为null;

首先可以肯定 加载顺序与他们在web.xml 文件中的先后顺序无关。

web.xml 中 listener 和 serverlet 的加载顺序为 先 listener 后serverlet

最终得出结果:先 listener >> filter >> servlet >> spring

所以,如果过滤器中要使用到 bean,可以将spring 的加载 改成 Listener的方式

<listener>
        <listener-class>
            org.springframework.web.context.ContextLoaderListener
        </listener-class>
    </listener>



搞定!

关于他们的内部执行顺序,也需要注意,如下面文章中遇到的问题

web.xml的filter执行顺序导致的乱码,切记!

发现引起bug的原因是web.xml的下面几行:

<filter-mapping>
        <filter-name>SecurityFilter</filter-name>
        <url-pattern>*.do</url-pattern>
    </filter-mapping>

    <filter-mapping>
        <filter-name>CharacterEncoding</filter-name>
        <url-pattern>*.do</url-pattern>
    </filter-mapping>

    <filter-mapping>
        <filter-name>CharacterEncoding</filter-name>
        <url-pattern>*.jsp</url-pattern>
    </filter-mapping>


根据servlet2.3规范filter执行是按照web.xml配置的filter-mapping先后顺序进行执行,所以上面的配置会导致遇见*.do的url请求,先进行SecurityFilter的过滤器处理,这时候没有做编码处理,已经是乱码,到下面的filter处理时已经时乱码,再做编码处理已经没有用处。

修正方式,调整filter-mapping顺序,如下:

  <filter-mapping>
        <filter-name>CharacterEncoding</filter-name>
        <url-pattern>*.do</url-pattern>
    </filter-mapping>

    <filter-mapping>
        <filter-name>CharacterEncoding</filter-name>
        <url-pattern>*.jsp</url-pattern>
    </filter-mapping>

    <filter-mapping>
        <filter-name>SecurityFilter</filter-name>
        <url-pattern>*.do</url-pattern>
    </filter-mapping>




首先可以确定的一点是,不同类型节点的加载顺序与它们在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>里也可以使用通配符,比如:

<strong> <context-param>  
       <param-name>contextConfigLocation</param-name>  
       <param-value>  
           classpath*:/applicationContext.xml,classpath*:/applicationContext-security.xml  
       </param-value>  
</context-param> </strong>


接着初始化listener, 主要子元素为< listener-class>,如:

<listener>  
     <listener-class>  
         org.springframework.web.context.ContextLoaderListener  
     </listener-class>  
</listener>  


然后是filter。 filter元素主要包括<filter-name>,<filter-class>和<init-param>, 一个典型的<filter>节点声明如下:

<filter>
    <filter-name>Cache Filter - Friendly</filter-name>
    <filter-class>com.liferay.portal.servlet.filters.cache.CacheFilter</filter-class>
    <init-param>
        <param-name>pattern</param-name>
        <param-value>0</param-value>
    </init-param>
</filter>


filter-mapping用来定义filter所对应的url匹配模式,它有两个子元素,分别是<filter-name>和<url-pattern>,一个典型的<filter-mapping>节点如下:

 <filter-mapping>
     <filter-name>Cache Filter - Layout</filter-name>
     <url-pattern>/c/portal/layout</url-pattern>
 </filter-mapping>


注意: 对于同一类型的配置节而言,与它们出现的顺序是有关的。以<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声明如下:

<servlet>
    <servlet-name>Friendly URL Servlet - Private User</servlet-name>
    <servlet-class>com.liferay.portal.servlet.FriendlyURLServlet</servlet-class>
    <init-param>
        <param-name>user</param-name>
        <param-value>true</param-value>
    </init-param>
    <load-on-startup>2</load-on-startup>
</servlet>
<servlet-mapping>
        <servlet-name>Friendly URL Servlet - Private User</servlet-name>
        <url-pattern>/user/*</url-pattern>
</servlet-mapping>


其中的<load-on-startup>值为正数或零时:Servlet容器先加载数值小的servlet,再依次加载其他数值大的servlet. 当值为负或未定义:Servlet容器将在Web客户首次访问这个servlet时加载它.
分享到:
评论
发表评论

文章已被作者锁定,不允许评论。

相关推荐

    Tomcat中用web.xml控制Web应用详解

    load-on-startup 元素用于指定 Servlet 的加载顺序。当值为 0 或者大于 0 时,表示容器在应用启动时就加载这个 Servlet。正数的值越小,启动该 Servlet 的优先级越高。 filter 元素 filter 元素用于配置过滤器。...

    tomcat配置文件web.xml与server.xml解析

    &lt;load-on-startup&gt;1&lt;/load-on-startup&gt; 在上面的配置中,定义了一个名为"default"的 Servlet,类名为 org.apache.catalina.servlets.DefaultServlet,並設置了兩個初始参数:debug 和 listings。 2. Servlet ...

    javaWEB总结(2): load-on-startup节点

    load-on-startup节点的试验代码,详情请参考博文:http://blog.csdn.net/daochuwenziyao/article/details/53026185

    关于JSP配置文件web.xml加载顺序详解

    一、 1、启动一个WEB项目的时候,WEB容器会去读取它的配置...load-on-startup 元素在web应用启动的时候指定了servlet被加载的顺序,它的值必须是一个整数。如果它的值是一个负整数或是这个元素不存在,那么容器会在该s

    Spring MVC Demo

    &lt;load-on-startup&gt;1&lt;/load-on-startup&gt; &lt;!-- 配置所有以.do结尾的请求交给DispatcherServlet进行处理,也可以设置其他值,如.action等 --&gt; &lt;servlet-mapping&gt; &lt;servlet-name&gt;Dispatcher&lt;/servlet-name&gt; ...

    zk 配置的web.xml

    &lt;description&gt;ZK loader for ZUML pages &lt;servlet-name&gt;zkLoader&lt;/servlet-name&gt; ... &lt;!-- 必须指定更新引擎(DHtmlUpdateServlet)的URI,并且... &lt;load-on-startup&gt;1&lt;/load-on-startup&gt;&lt;!-- Must --&gt; &lt;/servlet&gt;

    详解servlet配置load-on-startup的作用

    本文对load-on-startup的相关内容作了详细介绍,然后通过具体实例向大家展示了其作用,希望可以给大家一个参考。

    基于java的企业级应用开发:Spring MVC的核心类和注解.ppt

    * * * * Spring MVC的核心类和...&lt;param-name&gt;contextConfigLocation&lt;/param-name&gt; &lt;param-value&gt;classpath:springmvc-config.xml&lt;/param-value&gt; &lt;/init-param&gt; &lt;load-on-startup&gt;1&lt;/load-on-startup&gt; &lt;/servlet&gt; &lt;se

    spring mvc

    &lt;load-on-startup&gt;1&lt;/load-on-startup&gt; &lt;servlet-mapping&gt; &lt;servlet-name&gt;account&lt;/servlet-name&gt; &lt;url-pattern&gt;*.do&lt;/url-pattern&gt; &lt;/servlet-mapping&gt; 要与web-inf里面account-servlet.xml名字对应、要...

    spring MVC 配置文档

    &lt;load-on-startup&gt;1&lt;/load-on-startup&gt; &lt;/servlet&gt; 加载 DispatcherServlet 时 Spring 会尝试读取配置文件 默认的配置文件位于 web.xml 相同的路径下 文件名与注册的 Servlet 名有关 Servlet注册名跟上 -...

    Spring MVC 框架应用实例

    &lt;load-on-startup&gt;1&lt;/load-on-startup&gt; &lt;servlet-mapping&gt; &lt;servlet-name&gt;ideawu&lt;/servlet-name&gt; &lt;url-pattern&gt;*.do&lt;/url-pattern&gt; &lt;/servlet-mapping&gt; &lt;welcome-file-list&gt; &lt;welcome-file&gt;index.jsp...

    简单spring MVC 配置

    适合初学者的文档,&lt;web-app&gt; ... &lt;load-on-startup&gt;1&lt;/load-on-startup&gt; &lt;servlet-mapping&gt; &lt;servlet-name&gt;test&lt;/servlet-name&gt; &lt;url-pattern&gt;*.do&lt;/url-pattern&gt; &lt;/servlet-mapping&gt; &lt;/web-app&gt;

    spring MVC配置详解

    &lt;load-on-startup&gt;1&lt;/load-on-startup&gt; &lt;servlet-mapping&gt; &lt;servlet-name&gt;spring&lt;/servlet-name&gt; &lt;url-pattern&gt;*.do&lt;/url-pattern&gt; &lt;/servlet-mapping&gt; ``` 三、Spring 配置 在 web.xml 文件中配置 ...

    FCK在线编辑器源码及部署项目引用示例

    &lt;load-on-startup&gt;1&lt;/load-on-startup&gt; &lt;servlet-name&gt;SimpleUploader&lt;/servlet-name&gt; &lt;servlet-class&gt; com.FCKeditor.uploader.SimpleUploaderServlet &lt;/servlet-class&gt; &lt;init-param&gt; &lt;param-name&gt;...

    web.xml标签说明.docx

    `&lt;load-on-startup&gt;` 元素指定当 Web 应用程序启动时,servlet 被加载的次序。元素的内容必须是一个整型值,如果这个值是一个负数,或者没有设定这个元素,servlet 容器将在客户端首次请求这个 servlet 时加载它;...

    EurekaLog_7.5.0.0_Enterprise

    8)....Fixed: Removed some unnecessary file system access on startup 9)....Fixed: Possible wrong font size in EurekaLog tools 10)..Fixed: Ignore timeouts from Shell_NotifyIcon 11)..Fixed: Possible ...

    windows版wget命令

    -r, --recursive recursive web-suck -- use with care!. -l, --level=NUMBER maximum recursion depth (0 to unlimit). --delete-after delete downloaded files. -k, --convert-links convert non-relative...

    Fluent12.0 help

    1.1.5 Command Line Startup Options . . . . . . . . . . . . . . . . . . 1-9 1.1.6 Remote Simulation Facility (RSF) . . . . . . . . . . . . . . . . . 1-15 1.2 Running ANSYS FLUENT in Batch Mode . . . . ...

    wget-1.11.4-1

    --load-cookies=FILE load cookies from FILE before session. --save-cookies=FILE save cookies to FILE after session. --keep-session-cookies load and save session (non-permanent) cookies. --post-data...

    springweb3.0MVC注解(附实例)

    &lt;load-on-startup&gt;2&lt;/load-on-startup&gt; &lt;/servlet&gt; &lt;servlet-mapping&gt; &lt;servlet-name&gt;annomvc&lt;/servlet-name&gt; &lt;url-pattern&gt;*.do&lt;/url-pattern&gt; &lt;/servlet-mapping&gt; &lt;/web-app&gt; 清单 3. annomvc-servlet....

Global site tag (gtag.js) - Google Analytics