• web.xml文件中配置( listenr, filter,servlet, spring)的加载顺序 研究(转)


    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执行顺序导致的乱码,切记!
    2008-05-02 01:38
    发现引起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>

    本文来自CSDN博客,转载请标明出处:http://blog.csdn.net/wayfoon322/archive/2008/05/08/2418011.aspx

    ----------------------------------------------------------------------------------------------------------

    首先可以确定的一点是, 不同类型节点的加载顺序与它们在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>的键值: 

    1 ServletContext servletContext = contextEvent.getServletContext(); 
    2 Object context-param的值 = servletContext .getInitParameter("context-param的键");

    <context-param>包含两个子元素,分别是<param-name>和<param-value>。 前者用来设置context的名字,后者用来设置其值。

    当param-value有多个值时, 用逗号隔开。 <param-value>里也可以使用通配符,比如:

    1 <strong> <context-param>  
    2        <param-name>contextConfigLocation</param-name>  
    3        <param-value>  
    4            classpath*:/applicationContext.xml,classpath*:/applicationContext-security.xml  
    5        </param-value>  
    6 </context-param> </strong>

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

    1 <listener>  
    2     <listener-class>  
    3         org.springframework.web.context.ContextLoaderListener  
    4     </listener-class>  
    5 </listener>  

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

    1 <filter>
    2     <filter-name>Cache Filter - Friendly</filter-name>
    3     <filter-class>com.liferay.portal.servlet.filters.cache.CacheFilter</filter-class>
    4     <init-param>
    5         <param-name>pattern</param-name>
    6         <param-value>0</param-value>
    7     </init-param>
    8 </filter>

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

    1 <filter-mapping>
    2     <filter-name>Cache Filter - Layout</filter-name>
    3     <url-pattern>/c/portal/layout</url-pattern>
    4 </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声明如下:

     1 <servlet>
     2     <servlet-name>Friendly URL Servlet - Private User</servlet-name>
     3     <servlet-class>com.liferay.portal.servlet.FriendlyURLServlet</servlet-class>
     4     <init-param>
     5         <param-name>user</param-name>
     6         <param-value>true</param-value>
     7     </init-param>
     8     <load-on-startup>2</load-on-startup>
     9 </servlet>
    10 <servlet-mapping>
    11         <servlet-name>Friendly URL Servlet - Private User</servlet-name>
    12         <url-pattern>/user/*</url-pattern>
    13 </servlet-mapping>

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

  • 相关阅读:
    八.正文处理命令及tar命令
    七.用户.群组及权限的深入讨论
    六.用户.群组和权限
    五.目录,文件的浏览,管理和维护
    四.linux 命令及获取帮助
    计算机的基础知识
    三.linux基本的50条命令
    二.Python的基本数据类型及常用功能
    一.编码的转换和基本的算法
    Linux开机自动挂载Windows分区
  • 原文地址:https://www.cnblogs.com/laj12347/p/3063833.html
Copyright © 2020-2023  润新知