关闭

Web容器启动时加载Spring分析

841人阅读 评论(0) 收藏 举报

在应用程序web.xml中做了以下配置信息时,当启动Web容器时就会自动加载Spring容器。

[java] view plain copy
 print?
  1. <listener>  
  2.   
  3.     <listener-class>org.springframework.web.context.ContextLoaderListener</listener-class>  
  4.   
  5. </listener>  

ContextLoaderListener类实现了javax.servlet.ServletContextListener接口并且继承了org.springframework.web.context.ContextLoader类。ServletContextListener事件类是Web容器的一部分,处理Web应用的Servlet上下文(context)的监听。实现ServletContextListener接口中的contextInitialized和contextDestroyed方法。当Web容器启动时会自动调用contextInitialized方法,进行初始化Spring Web应用程序上下文,主要加载web.xml中contextConfigLocation的配置文件;当Web容器关闭之前会调用contextDestroyed方法,进行销毁Spring Web应用程序上下文。ContextLoader类实现了Spring上下文初始化的工作,执行initWebApplicationContext方法返回WebApplicationContext。Spring实现的contextInitialized和contextDestroyed代码如下:
[java] view plain copy
 print?
  1. public void contextInitialized(ServletContextEvent event) {  
  2.   
  3.        this.contextLoader = createContextLoader();  
  4.   
  5.        if (this.contextLoader ==null) {  
  6.   
  7.            this.contextLoader = this;  
  8.   
  9.        }  
  10.   
  11.     this.contextLoader.initWebApplicationContext(event.getServletContext());  
  12.   
  13.     }  
  14.   
  15.    
  16.   
  17. public void contextDestroyed(ServletContextEvent event) {  
  18.   
  19.        if (this.contextLoader !=null) {        
[java] view plain copy
 print?
  1. this.contextLoader.closeWebApplicationContext(event.getServletContext());  
[java] view plain copy
 print?
  1. }  
  2.   
  3.  ContextCleanupListener.cleanupAttributes(event.getServletContext());  
[java] view plain copy
 print?
  1. }  
  2.    
Spring执行实现Spring上下文的方法
[java] view plain copy
 print?
  1. public WebApplicationContext initWebApplicationContext(ServletContext servletContext) {  
  2.   
  3.         if (servletContext.getAttribute(WebApplicationContext.ROOT_WEB_APPLICATION_CONTEXT_ATTRIBUTE) !=null) {  
  4.   
  5.             throw new IllegalStateException(  
  6.   
  7.                     "Cannot initialize context because there is already a root application context present - " +  
  8.   
  9.                     "check whether you have multiple ContextLoader* definitions in your web.xml!");  
  10.   
  11.         }  
  12.   
  13.    
  14.   
  15.         Log logger = LogFactory.getLog(ContextLoader.class);  
  16.   
  17.         servletContext.log("Initializing Spring root WebApplicationContext");  
  18.   
  19.         if (logger.isInfoEnabled()) {  
  20.   
  21.             logger.info("Root WebApplicationContext: initialization started");  
  22.   
  23.         }  
  24.   
  25.         long startTime = System.currentTimeMillis();  
  26.   
  27.    
  28.   
  29.         try {  
  30.   
  31.             // Store context in local instance variable, to guarantee that  
  32.   
  33.             // it is available on ServletContext shutdown.  
  34.   
  35.             if (this.context ==null) {  
  36.   
  37.                 this.context = createWebApplicationContext(servletContext);  
  38.   
  39.             }  
  40.   
  41.             if (this.context instanceof ConfigurableWebApplicationContext) {  
  42.   
  43.                 configureAndRefreshWebApplicationContext((ConfigurableWebApplicationContext)this.context, servletContext);  
  44.   
  45.             }  
  46.   
  47.             servletContext.setAttribute(WebApplicationContext.ROOT_WEB_APPLICATION_CONTEXT_ATTRIBUTE,this.context);  
  48.   
  49.    
  50.   
  51.             ClassLoader ccl = Thread.currentThread().getContextClassLoader();  
  52.   
  53.             if (ccl == ContextLoader.class.getClassLoader()) {  
  54.   
  55.                 currentContext = this.context;  
  56.   
  57.             }  
  58.   
  59.             else if (ccl != null) {  
  60.   
  61.                 currentContextPerThread.put(ccl, this.context);  
  62.   
  63.             }  
  64.   
  65.    
  66.   
  67.             if (logger.isDebugEnabled()) {  
  68.   
  69.                 logger.debug("Published root WebApplicationContext as ServletContext attribute with name [" +  
  70.   
  71.                         WebApplicationContext.ROOT_WEB_APPLICATION_CONTEXT_ATTRIBUTE + "]");  
  72.   
  73.             }  
  74.   
  75.             if (logger.isInfoEnabled()) {  
  76.   
  77.                 long elapsedTime = System.currentTimeMillis() - startTime;  
  78.   
  79.                 logger.info("Root WebApplicationContext: initialization completed in " + elapsedTime + " ms");  
  80.   
  81.             }  
  82.   
  83.    
  84.   
  85.             return this.context;  
  86.   
  87.         }  
  88.   
  89.         catch (RuntimeException ex) {  
  90.   
  91.             logger.error("Context initialization failed", ex);  
  92.   
  93.             servletContext.setAttribute(WebApplicationContext.ROOT_WEB_APPLICATION_CONTEXT_ATTRIBUTE, ex);  
  94.   
  95.             throw ex;  
  96.   
  97.         }  
  98.   
  99.         catch (Error err) {  
  100.   
  101.             logger.error("Context initialization failed", err);  
  102.   
  103.             servletContext.setAttribute(WebApplicationContext.ROOT_WEB_APPLICATION_CONTEXT_ATTRIBUTE, err);  
  104.   
  105.             throw err;  
  106.   
  107.         }  
  108.   
  109.     }  
0
0
查看评论
发表评论
* 以上用户言论只代表其个人观点,不代表CSDN网站的观点或立场

check whether you have multiple ContextLoader* definitions in your web.xml

check whether you have multiple ContextLoader* definitions in your web.xml! java.lang.IllegalStateE...
  • hong0220
  • hong0220
  • 2014-11-17 11:20
  • 4168

Java之旅--Web.xml解析

Windows的IIS,是用UI界面进行站点的配置;Linux下面的几乎所有系统,都是使用配置文件来进行配置,Java容器(JBoss/Tomcat/Jetty/WebSphere/WebLogic等...
  • puma_dong
  • puma_dong
  • 2014-07-18 23:47
  • 2078

SpringMVC容器初始化篇----ContextLoaderListener

此篇幅主要围绕着 ContextLoaderListener理解其中的原理。 contextConfigLocation classpath*:server_spring.xml ...
  • zjw10wei321
  • zjw10wei321
  • 2014-10-16 12:04
  • 34808

spring(4)---加载spring容器的3种方式

方法1: //方法1:在类路径下寻找配置文件来实例化容器 ApplicationContext ctx=new ClassPathXmlApplicationContext("classpath:...
  • sinat_23490433
  • sinat_23490433
  • 2017-02-08 15:55
  • 1217

使用web.xml方式加载Spring时,获取Spring context的两种方式

使用web.xml方式加载Spring时,获取Spring context的两种方式:   1、servlet方式加载时: 【web.xml】           dispatcherSe...
  • rnZuoZuo
  • rnZuoZuo
  • 2014-03-30 05:13
  • 2061

通过web.xml文件自动启动spring容器加载对应的配置文件

在web开发中可以在web.xml文件中配置自启动的servlet或者web容器监听器,借助两者中的任何一者都可以完成启动spring web应用上下文的工作。 下面给出使用web监听器的方式来实现启...
  • see__you__again
  • see__you__again
  • 2016-04-21 21:29
  • 1825

freemarker写select组件报错总结(四)

1、错误描述 freemarker 下拉框 Error parsing imported template inc/select.ftl Th...
  • you23hai45
  • you23hai45
  • 2014-06-26 00:21
  • 3943

Web容器启动时加载Spring

在应用程序web.xml中做了以下配置信息时,当启动Web容器时就会自动加载Spring容器。 org.springframework.web.context.C...
  • lanpiao_87
  • lanpiao_87
  • 2011-10-06 11:48
  • 5666

Tomcat启动时加载数据到缓存---web.xml中listener加载顺序(优先初始化Spring IOC容器)

JavaWebSpringTomcatCache        最近用到在Tomcat服务器启动时自动加载数据到缓存,这就需要创建一个自定义的缓存监听器并实现ServletContextLi...
  • u013700340
  • u013700340
  • 2014-08-06 23:45
  • 2692

Tomcat启动时加载数据到缓存--Web.xml里listener的加载顺序,优先初始化Spring IOC容器

最近用到在Tomcat服务器启动时自动加载数据到缓存,这就需要创建一个自定义的缓存监听器并实现ServletContextListener接口,并且在此自定义监听器中需要用到Spring的依赖注入功能...
  • u011217058
  • u011217058
  • 2017-07-25 14:41
  • 863
    个人资料
    • 访问:155010次
    • 积分:3273
    • 等级:
    • 排名:第12207名
    • 原创:154篇
    • 转载:231篇
    • 译文:2篇
    • 评论:13条
    最新评论