Spring中ApplicationContext加载机制和配置初始化
2016-04-13 00:48
423 查看
Spring中ApplicationContext加载机制。
加载器目前有两种选择:ContextLoaderListener和ContextLoaderServlet。
这两者在功能上完全等同,只是一个是基于Servlet2.3版本中新引入的Listener接口实现,而另一个基于Servlet接口实现。开发中可根据目标Web容器的实际情况进行选择。
配置非常简单,在web.xml中增加:
Xml代码
<listener>
<listener-class>
org.springframework.web.context.ContextLoaderListener
</listener-class>
</listener>
或:
Xml代码
<servlet>
<servlet-name>context</servlet-name>
<servlet-class>
org.springframework.web.context.ContextLoaderServlet
</servlet-class>
<load-on-startup>1</load-on-startup>
</servlet>
通过以上配置,Web容器会自动加载/WEB-INF/applicationContext.xml初始化
ApplicationContext实例,如果需要指定配置文件位置,可通过context-param加以指定:
Xml代码
<context-param>
<param-name>contextConfigLocation</param-name>
<param-value>/WEB-INF/myApplicationContext.xml</param-value>
</context-param>
配置完成之后,即可通过
WebApplicationContextUtils.getWebApplicationContext方法在Web应用中获取ApplicationContext引用。
如:
Java代码
ApplicationContext ctx=WebApplicationContextUtils.getWebApplicationContext();
LoginAction action=(LoginAction)ctx.getBean("action");
-------------------------------------------------------------------------------------------
spring为ApplicationContext提供有三种实现(举例)
spring为ApplicationContext提供的3种实现分别为:ClassPathXmlApplicationContext,FileSystemXmlApplicationContext和XmlWebApplicationContext,其中XmlWebApplicationContext是专为Web工程定制的。使用举例如下:
1. FileSystemXmlApplicationContext
Java代码
//eg1.
ApplicationContext ctx = new FileSystemXmlApplicationContext("bean.xml"); //加载单个配置文件
//eg2.
String[] locations = {"bean1.xml", "bean2.xml", "bean3.xml"};
ApplicationContext ctx = new FileSystemXmlApplicationContext(locations ); //加载多个配置文件
//eg3.
ApplicationContext ctx =new FileSystemXmlApplicationContext("D:/project/bean.xml");//根据具体路径加载文件
2. ClassPathXmlApplicationContext
Java代码
//eg1.
ApplicationContext ctx = new ClassPathXmlApplicationContext("bean.xml");
//eg2.
String[] locations = {"bean1.xml", "bean2.xml", "bean3.xml"};
ApplicationContext ctx = new ClassPathXmlApplication(locations);
注:其中FileSystemXmlApplicationContext和ClassPathXmlApplicationContext与BeanFactory的xml文件定位方式一样是基于路径的。
3. XmlWebApplicationContext
Java代码
eg1.
ServletContext servletContext = request.getSession().getServletContext();
ApplicationContext ctx = WebApplicationContextUtils.getWebApplicationContext(servletContext);
注 : 一般是 ApplicationContext ctx = WebApplicationContextUtils.getWebApplicationContext(this.getServletContext());
配置初始化
1. 在struts-config.xml里,以插件的形式
Xml代码
<plug-in className="org.springframework.web.struts.ContextLoaderPlugIn" />
<set-property property="contextConfigLocation" value="/WEB-INF/applicationContext.xml"/>
</plug-in >
这种方式如果没有配置contextConfigLocation的值,则会自动加载xx-servlet.xml.xx的值是和web.xml里的配置org.apache.struts.action.ActionServlet的servlet-name的值一样如下:xx的值也就是 action,所以会自动加载action-servlet.xml
Xml代码
<servlet>
<servlet-name>action</servlet-name >
<servlet-class>org.apache.struts.action.ActionServlet</servlet-class>
<load-on-startup>1</load-on-startup>
</servlet>
<servlet-mapping>
<servlet-name >action</servlet-name>
<url-pattern>*.do</url-pattern>
</servlet-mapping>
如果sturts-config.xml里配置了contextConfigLocation的值,那么就不会自动加载xx-servlet.xml了,而只会加载contextConfigLocation所指定的xml. 2. 第2种方式在web.xml里配置Listener
Xml代码
<listener>
<listener-class>org.springframework.web.context.ContextLoaderListenerlistener-class>
</listener>
如果在web.xml里给该Listener指定要加载的xml,如:
Xml代码
<context-param>
<param-name>contextConfigLocation<param-name>
<param-value>classpath*:spring/*.xml<param-value>
<context-param>
则会去加载相应的xml,而不会去加载/WEB-INF/下的applicationContext.xml。。但是,如果没有指定的话,默认会去/WEB-INF/下加载applicationContext.xml。
3. 第三种方式:ContextLoaderServlet
Xml代码
<servlet>
<servlet-name>context</servlet-name>
<servlet-class>org.springframework.web.context.ContextLoaderServlet</servlet-class>
<load-on-startup>1</load-on-startup>
</servlet>
这种方式和第二种Listener方式一样,唯一的区别就是用Listener方式初始化ApplicationContext,可以和用第一种方式(struts-config.xml里 plugin方式)同时存在,而ContextLoaderServlet则不可以和第一种方式同时存在
总结:
ContextLoaderServlet已经不推荐用了,它只是为了兼容低版本的servlet.jar才用的。
总的来说:Listerner要比Servlet更好一些,而且Listerner监听应用的启动和结束,而Servlet启动要稍微延迟一些。
加载器目前有两种选择:ContextLoaderListener和ContextLoaderServlet。
这两者在功能上完全等同,只是一个是基于Servlet2.3版本中新引入的Listener接口实现,而另一个基于Servlet接口实现。开发中可根据目标Web容器的实际情况进行选择。
配置非常简单,在web.xml中增加:
Xml代码
<listener>
<listener-class>
org.springframework.web.context.ContextLoaderListener
</listener-class>
</listener>
或:
Xml代码
<servlet>
<servlet-name>context</servlet-name>
<servlet-class>
org.springframework.web.context.ContextLoaderServlet
</servlet-class>
<load-on-startup>1</load-on-startup>
</servlet>
通过以上配置,Web容器会自动加载/WEB-INF/applicationContext.xml初始化
ApplicationContext实例,如果需要指定配置文件位置,可通过context-param加以指定:
Xml代码
<context-param>
<param-name>contextConfigLocation</param-name>
<param-value>/WEB-INF/myApplicationContext.xml</param-value>
</context-param>
配置完成之后,即可通过
WebApplicationContextUtils.getWebApplicationContext方法在Web应用中获取ApplicationContext引用。
如:
Java代码
ApplicationContext ctx=WebApplicationContextUtils.getWebApplicationContext();
LoginAction action=(LoginAction)ctx.getBean("action");
-------------------------------------------------------------------------------------------
spring为ApplicationContext提供有三种实现(举例)
spring为ApplicationContext提供的3种实现分别为:ClassPathXmlApplicationContext,FileSystemXmlApplicationContext和XmlWebApplicationContext,其中XmlWebApplicationContext是专为Web工程定制的。使用举例如下:
1. FileSystemXmlApplicationContext
Java代码
//eg1.
ApplicationContext ctx = new FileSystemXmlApplicationContext("bean.xml"); //加载单个配置文件
//eg2.
String[] locations = {"bean1.xml", "bean2.xml", "bean3.xml"};
ApplicationContext ctx = new FileSystemXmlApplicationContext(locations ); //加载多个配置文件
//eg3.
ApplicationContext ctx =new FileSystemXmlApplicationContext("D:/project/bean.xml");//根据具体路径加载文件
2. ClassPathXmlApplicationContext
Java代码
//eg1.
ApplicationContext ctx = new ClassPathXmlApplicationContext("bean.xml");
//eg2.
String[] locations = {"bean1.xml", "bean2.xml", "bean3.xml"};
ApplicationContext ctx = new ClassPathXmlApplication(locations);
注:其中FileSystemXmlApplicationContext和ClassPathXmlApplicationContext与BeanFactory的xml文件定位方式一样是基于路径的。
3. XmlWebApplicationContext
Java代码
eg1.
ServletContext servletContext = request.getSession().getServletContext();
ApplicationContext ctx = WebApplicationContextUtils.getWebApplicationContext(servletContext);
注 : 一般是 ApplicationContext ctx = WebApplicationContextUtils.getWebApplicationContext(this.getServletContext());
配置初始化
1. 在struts-config.xml里,以插件的形式
Xml代码
<plug-in className="org.springframework.web.struts.ContextLoaderPlugIn" />
<set-property property="contextConfigLocation" value="/WEB-INF/applicationContext.xml"/>
</plug-in >
这种方式如果没有配置contextConfigLocation的值,则会自动加载xx-servlet.xml.xx的值是和web.xml里的配置org.apache.struts.action.ActionServlet的servlet-name的值一样如下:xx的值也就是 action,所以会自动加载action-servlet.xml
Xml代码
<servlet>
<servlet-name>action</servlet-name >
<servlet-class>org.apache.struts.action.ActionServlet</servlet-class>
<load-on-startup>1</load-on-startup>
</servlet>
<servlet-mapping>
<servlet-name >action</servlet-name>
<url-pattern>*.do</url-pattern>
</servlet-mapping>
如果sturts-config.xml里配置了contextConfigLocation的值,那么就不会自动加载xx-servlet.xml了,而只会加载contextConfigLocation所指定的xml. 2. 第2种方式在web.xml里配置Listener
Xml代码
<listener>
<listener-class>org.springframework.web.context.ContextLoaderListenerlistener-class>
</listener>
如果在web.xml里给该Listener指定要加载的xml,如:
Xml代码
<context-param>
<param-name>contextConfigLocation<param-name>
<param-value>classpath*:spring/*.xml<param-value>
<context-param>
则会去加载相应的xml,而不会去加载/WEB-INF/下的applicationContext.xml。。但是,如果没有指定的话,默认会去/WEB-INF/下加载applicationContext.xml。
3. 第三种方式:ContextLoaderServlet
Xml代码
<servlet>
<servlet-name>context</servlet-name>
<servlet-class>org.springframework.web.context.ContextLoaderServlet</servlet-class>
<load-on-startup>1</load-on-startup>
</servlet>
这种方式和第二种Listener方式一样,唯一的区别就是用Listener方式初始化ApplicationContext,可以和用第一种方式(struts-config.xml里 plugin方式)同时存在,而ContextLoaderServlet则不可以和第一种方式同时存在
总结:
ContextLoaderServlet已经不推荐用了,它只是为了兼容低版本的servlet.jar才用的。
总的来说:Listerner要比Servlet更好一些,而且Listerner监听应用的启动和结束,而Servlet启动要稍微延迟一些。
相关文章推荐
- codeforec 602B Approximating a Constant Range
- IOS 应用 分享 扩展
- 移动端与服务端数据交互时的一个坑
- 匿名对象和object的转换
- Android ListView实现上拉到底部的时候自动刷新数据
- Android动态加载基础 ClassLoader工作机制
- Qt for Android环境搭建浅谈
- Android BottomNavigationBar的使用
- Java加密解密工具(适用于JavaSE/JavaEE/Android)
- javascript函数apply的使用和理解
- 我黑了一个少妇的微信,结果发现……
- Apple Watch一岁了,它过得还好吗?
- 不要担心 微信没说要禁止H5推广,但前提是你得守规矩
- Android 编码规范
- ios pickerview选择城市
- iOS 通知传值(顺传)
- Android_基础知识掌握
- android listview 执行notifyDataSetChanged 不更新数据的原因
- 这个小游戏,在微信朋友圈引起了上亿人的关注
- Mac下cocoapods使用说明(2016版)