Spring上下文ContextLoaderListener做用

配置文件java

<listener>
		<listener-class>com.xspace.modules.sys.listener.WebContextListener</listener-class>
	</listener>

代碼
web

public class WebContextListener extends org.springframework.web.context.ContextLoaderListener {
	
	@Override
	public WebApplicationContext initWebApplicationContext(ServletContext servletContext) {
		if (!SystemService.printKeyLoadMessage()){
			return null;
		}
		return super.initWebApplicationContext(servletContext);
	}
}


1·ContextLoaderListener 用法

ContextLoaderListener監聽器的做用就是啓動Web容器時,自動裝配ApplicationContext的配置信息。由於它實現了ServletContextListener這個接口,在web.xml配置這個監聽器,啓 動容器時,就會默認執行它實現的方法。spring

至於ApplicationContext.xml這個配置文件部署在哪,如何配置多個xml文件,書上都沒怎麼詳 細說明。如今的方法就是查看它的API文檔。在ContextLoaderListener中關聯了ContextLoader這個類,因此整個加載配置 過程由ContextLoader來完成。看看它的API說明。

第一段說明ContextLoader能夠由 ContextLoaderListener和ContextLoaderServlet生成。若是查看ContextLoaderServlet的 API,能夠看到它也關聯了ContextLoader這個類並且它實現了HttpServlet這個接口。

 第二段,ContextLoader建立的是 XmlWebApplicationContext這樣一個類,它實現的接口是 WebApplicationContext->ConfigurableWebApplicationContext->ApplicationContext->BeanFactory 這樣一來spring中的全部bean都由這個類來建立

第三段,講如何部署applicationContext的xml文件。app

若是在web.xml中不寫任何參數配置信息,默認的路徑是/WEB-INF/applicationContext.xml,在WEB-INF目錄下建立的xml文件的名稱必須是applicationContext.xml;ide

若是是要自定義文件名能夠在web.xml里加入contextConfigLocation這個context參數:
<context-param> 
        <param-name>contextConfigLocation</param-name> 
        <param-value> 
            /WEB-INF/classes/applicationContext-*.xml  
        </param-value> 
    </context-param> 
在<param-value> </param-value>裏指定相應的xml文件名,若是有多個xml文件,能夠寫在一塊兒並一「,」號分隔。上面的 applicationContext-*.xml採用通配符,工具

好比這那個目錄下有applicationContext-ibatis- base.xml,applicationContext-action.xml,applicationContext-ibatis-dao.xml 等文件,都會一同被載入。

因而可知applicationContext.xml的文件位置就能夠有兩種默認實現:

第一種:直接將之放到/WEB-INF下,之在web.xml中聲明一個listener;

第二種:將之放到classpath下,可是此時要在web.xml中加入<context-param>,用它來指明你的 applicationContext.xml的位置以供web容器來加載。按照Struts2 整合spring的官方給出的檔案,寫成:
<context-param> 
    <param-name>contextConfigLocation</param-name> 
    <param-value>/WEB-INF/applicationContext-*.xml,classpath*:applicationContext-*.xml</param-value> 
</context-param>this

2·initWebApplicationContext做用

ApplicationContext是Spring的核心,Context咱們一般解釋爲上下文環境,我想用「容器」來表述它更容易理解一些,ApplicationContext則是「應用的容器」了;在Web應用中,spa

咱們會用到WebApplicationContext,WebApplicationContext繼承自ApplicationContext;WebApplicationContext的初始化方式和BeanFactory.ApplicationContext有所區別,由於WebApplicationContext須要ServletContext實例,code

也就是說它必須擁有Web容器的前提下才能完成啓動的工做.有過Web開發經驗的讀者都知道能夠在web.xml中配置自啓動的Servlet或定義Web容器監聽器(ServletContextListener),藉助着二者中的任何一個,咱們就能夠啓動Spring Web應用上下文的工做.orm

Spring分別提供了用於啓動WebApplicationContext的Servlet和Web容器監聽器:

org.springframework.web.context.ContextLoaderServlet;

org.springframework.web.context.ContextLoaderListener.

這兩個方法都是在web應用啓動的時候來初始化WebApplicationContext,我我的認爲Listerner要比Servlet更好一些,由於Listerner監聽應用的啓動和結束,而Servlet得啓動要稍微延遲一些,若是在這時要作一些業務的操做,啓動的先後順序是有影響的。

配置例子以下:
context-param> 
<param-name>contextConfigLocation</param-name> 
<param-value>/WEB-INF/applicationContext.xml</param-value> 
</context-param> 

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

那麼在ContextLoaderListener和ContextLoaderServlet中到底作了什麼呢? 
以ContextLoaderListener爲例,咱們能夠看到 
public void contextInitialized(ServletContextEvent event) { 
this.contextLoader = createContextLoader(); 
this.contextLoader.initWebApplicationContext(event.getServletContext()); 

protected ContextLoader createContextLoader() { 
return new ContextLoader(); 

ContextLoader是一個工具類,用來初始化WebApplicationContext,其主要方法就是initWebApplicationContext,咱們繼續追蹤initWebApplicationContext這個方法(具體代碼我不貼出,你們能夠看Spring中的源碼),咱們發現,原來ContextLoader是把WebApplicationContext(XmlWebApplicationContext是默認實現類)放在了ServletContext中,ServletContext也是一個「容器」,也是一個相似Map的結構,

而WebApplicationContext在ServletContext中的KEY就是WebApplicationContext.ROOT_WEB_APPLICATION_CONTEXT_ATTRIBUTE,咱們若是要使用WebApplicationContext則須要從ServletContext取出,

Spring提供了一個WebApplicationContextUtils類,能夠方便的取出WebApplicationContext,只要把ServletContext傳入就能夠了。


ApplicationContext  咱們通常都是幹這個用的23333

ApplicationContext ctx = WebApplicationContextUtils.getWebApplicationContext(getServletContext());
		ProductMng productMng = (ProductMng)ctx.getBean("productMng");
相關文章
相關標籤/搜索