8 -- 深入使用Spring -- 3...4 在ApplicationContext中使用资源
8.3.4 在ApplicationContext中使用资源
不管以怎样的方式创建ApplicationContext实例,都需要为ApplicationContext指定配置文件,Spring允许使用一份或多分XML配置文件。
当程序创建ApplicationContext实例时,通常也是以Resource的方式来访问配置文件的,所以ApplicationContext完全支持ClassPathResource、FileSystemResource、ServletContextResource等资源访问方式。
ApplicationContext确定资源访问策略通常有两种方法:
⊙ 使用ApplicationContext实现类指定访问策略。
⊙ 使用前缀指定访问策略。
1.使用ApplicationContext实现类指定访问策略
创建ApplicationContext对象时,通常可以使用如下三个实现类:
⊙ ClassPathXMLApplicationContext : 对应使用ClassPathResource进行资源访问。
⊙ FileSystemXmlApplicationContext : 对应使用FileSystemResource进行资源访问。
⊙ XmlWebApplicationContext : 对应使用ServletContextResource进行资源访问。
当使用ApplicationContext的不同实现类时,就意味着Spring使用响应的资源访问策略。
2.使用前缀指定访问策略
Spring允许使用前缀来指定资源访问策略。
package edu.pri.lime._8_3_4.prefix.bean.main; import org.springframework.context.ApplicationContext;
import org.springframework.context.support.FileSystemXmlApplicationContext;
import org.springframework.core.io.Resource; public class SpringTest { public static void main(String[] args) {
/*
* 通过搜索文件系统路径下的xml文件创建ApplicationContext,
* 但通过指定classpath:前缀强制搜索类加载路径*/
ApplicationContext ctx = new FileSystemXmlApplicationContext("classpath:app_8_3_4.xml");
System.out.println(ctx);
/*使用ApplicationContext的资源访问策略来访问资源,没有指定前缀*/
Resource resource = ctx.getResource("book.xml");
System.out.println(resource.getFilename());
System.out.println(resource.getDescription());
}
}
Console :
org.springframework.context.support.FileSystemXmlApplicationContext@2752f6e2: startup date [Sun Feb 12 19:50:38 CST 2017]; root of context hierarchy
book.xml
file [E:\Users\Administrator\workspace\lime\book.xml]
系统从类加载路径下搜索xml;但使用ApplicationContext来访问资源时,依然采用的是FileSystemResource实现类,这与FileSystemXmlApplicationContext的访问策略是一致的。这表明:通过classpath:前缀指定资源访问策略仅仅对档次访问有效,程序后面进行资源访问时,还会根据ApplicationContext的实现类来选择对应的资源访问策略。
3.classpath*:前缀的用法
classpath*:前缀提供了加载多个XML配置文件的能力,当使用classpath*:前缀来指定XML配置文件时,系统将搜索类加载路径,找到所有与文件名匹配的文件,分别加载文件中的配置定义,最后合并成一个ApplicationContext。
package edu.pri.lime._8_3_4.prefixStart.bean.main; import org.springframework.context.ApplicationContext;
import org.springframework.context.support.FileSystemXmlApplicationContext; public class SpringTest { public static void main(String[] args) {
ApplicationContext ctx = new FileSystemXmlApplicationContext("classpath*:app_8_3_4.xml");
System.out.println(ctx);
}
}
将配置文件app_8_3_4.xml分别放在应用的classes路径(该路径被设为类加载路径之一)下,并将配置文件放在classes/8.3.4.3路径下(该路径也被设为类加载路径之一),程序实例化ApplicationContext时显示:
为什么不是想象中的两个Loading XML bean definitions? 信息: Loading XML bean definitions from URL [file:/E:/Users/Administrator/workspace/lime/target/classes/app_8_3_4.xml]
org.springframework.context.support.FileSystemXmlApplicationContext@2752f6e2: startup date [Mon Feb 13 21:30:37 CST 2017]; root of context hierarchy
当使用classpath*:前缀时,Spring将会搜索类加载路径下所有满足该规则的配置文件。
如果不是采用classpath*:前缀,而是改为使用classpath:前缀,Spring则只加载第一个符合条件的XML文件。
当使用classpath:前缀时,系统通过类加载路径搜索xml文件,如果找到文件名匹配的文件,系统立即停止搜索,加载该文件,即使有多个文件名匹配的文件,系统也只加载第一个文件。资源文件的搜索顺序取决于类加载路径的顺序,排在前面的配置文件将优先被加载。
注意 :
classpath*: 前缀仅对ApplicationContext有效。实际情况是,创建ApplicationContext时,分别访问多个配置文件(通过ClassLoader的getResource方法实现)。因此,classpath*:前缀不可用于Resource,使用classpath*:前缀一次性访问多个资源是行不通的。
一次性加载多个配置文件的方式:指定配置文件时使用通配符。
ApplicationContext ctx = new FileSystemXmlApplicationContext("classpath:app_8_3*.xml");
Console :
二月 13, 2017 9:56:35 下午 org.springframework.context.support.FileSystemXmlApplicationContext prepareRefresh
信息: Refreshing org.springframework.context.support.FileSystemXmlApplicationContext@2752f6e2: startup date [Mon Feb 13 21:56:35 CST 2017]; root of context hierarchy
二月 13, 2017 9:56:35 下午 org.springframework.beans.factory.xml.XmlBeanDefinitionReader loadBeanDefinitions
信息: Loading XML bean definitions from file [E:\Users\Administrator\workspace\lime\target\classes\app_8_3_2.xml]
二月 13, 2017 9:56:35 下午 org.springframework.beans.factory.xml.XmlBeanDefinitionReader loadBeanDefinitions
信息: Loading XML bean definitions from file [E:\Users\Administrator\workspace\lime\target\classes\app_8_3_3.xml]
二月 13, 2017 9:56:35 下午 org.springframework.beans.factory.support.DefaultListableBeanFactory registerBeanDefinition
信息: Overriding bean definition for bean 'testBean': replacing [Generic bean: class [edu.pri.lime._8_3_2.bean.impl.TestBean]; scope=singleton; abstract=false; lazyInit=false; autowireMode=0; dependencyCheck=0; autowireCandidate=true; primary=false; factoryBeanName=null; factoryMethodName=null; initMethodName=null; destroyMethodName=null; defined in file [E:\Users\Administrator\workspace\lime\target\classes\edu\pri\lime\_8_3_2\bean\impl\TestBean.class]] with [Generic bean: class [edu.pri.lime._8_3_3.bean.impl.TestBean]; scope=; abstract=false; lazyInit=false; autowireMode=0; dependencyCheck=0; autowireCandidate=true; primary=false; factoryBeanName=null; factoryMethodName=null; initMethodName=null; destroyMethodName=null; defined in file [E:\Users\Administrator\workspace\lime\target\classes\app_8_3_3.xml]]
二月 13, 2017 9:56:35 下午 org.springframework.beans.factory.xml.XmlBeanDefinitionReader loadBeanDefinitions
信息: Loading XML bean definitions from file [E:\Users\Administrator\workspace\lime\target\classes\app_8_3_4.xml]
Spring允许将classpath*:前缀和通配符结合使用:
ApplicationContext ctx = new FileSystemXmlApplicationContext("classpath*:app_8_3*.xml");
Console :
然而并没有什么不同。。。 二月 13, 2017 9:57:58 下午 org.springframework.context.support.FileSystemXmlApplicationContext prepareRefresh
信息: Refreshing org.springframework.context.support.FileSystemXmlApplicationContext@2752f6e2: startup date [Mon Feb 13 21:57:58 CST 2017]; root of context hierarchy
二月 13, 2017 9:57:58 下午 org.springframework.beans.factory.xml.XmlBeanDefinitionReader loadBeanDefinitions
信息: Loading XML bean definitions from file [E:\Users\Administrator\workspace\lime\target\classes\app_8_3_2.xml]
二月 13, 2017 9:57:58 下午 org.springframework.beans.factory.xml.XmlBeanDefinitionReader loadBeanDefinitions
信息: Loading XML bean definitions from file [E:\Users\Administrator\workspace\lime\target\classes\app_8_3_3.xml]
二月 13, 2017 9:57:58 下午 org.springframework.beans.factory.support.DefaultListableBeanFactory registerBeanDefinition
信息: Overriding bean definition for bean 'testBean': replacing [Generic bean: class [edu.pri.lime._8_3_2.bean.impl.TestBean]; scope=singleton; abstract=false; lazyInit=false; autowireMode=0; dependencyCheck=0; autowireCandidate=true; primary=false; factoryBeanName=null; factoryMethodName=null; initMethodName=null; destroyMethodName=null; defined in file [E:\Users\Administrator\workspace\lime\target\classes\edu\pri\lime\_8_3_2\bean\impl\TestBean.class]] with [Generic bean: class [edu.pri.lime._8_3_3.bean.impl.TestBean]; scope=; abstract=false; lazyInit=false; autowireMode=0; dependencyCheck=0; autowireCandidate=true; primary=false; factoryBeanName=null; factoryMethodName=null; initMethodName=null; destroyMethodName=null; defined in file [E:\Users\Administrator\workspace\lime\target\classes\app_8_3_3.xml]]
二月 13, 2017 9:57:58 下午 org.springframework.beans.factory.xml.XmlBeanDefinitionReader loadBeanDefinitions
信息: Loading XML bean definitions from file [E:\Users\Administrator\workspace\lime\target\classes\app_8_3_4.xml]
4.file:前缀的用法(然而并没有实现。。。why?)
package edu.pri.lime._8_3_4.prefixFile.bean.main; import org.springframework.context.ApplicationContext;
import org.springframework.context.support.FileSystemXmlApplicationContext;
import org.springframework.core.io.Resource; public class SpringTest { public static void main(String[] args) {
ApplicationContext ctx1 = new FileSystemXmlApplicationContext("app_8_3_4_4.xml");
System.out.println(ctx1);
ApplicationContext ctx2 = new FileSystemXmlApplicationContext("/app_8_3_4_4.xml");
System.out.println(ctx2);
Resource resource = ctx2.getResource("app_8_3_4.xml");
System.out.println(resource.getDescription());
}
}
当FileSystemXmlApplicationContext作为ResourceLoader使用时,FileSysteTemApplicationContext会简单地让所有绑定的FileSystemResource实例把绝对路径都当成相对路径处理,而不管是否以斜杠开头。
如果程序中需要访问绝对路径,则不要直接使用FileSystemResource或FileSystemXmlApplicationContext来指定绝对路径。建议强制使用file:前缀来区分相对路径和绝对路径。
ApplicationContext ctx1 = new FileSystemXmlApplicationContext("file:app_8_3_4_4.xml");
ApplicationContext ctx2 = new FileSystemXmlApplicationContext("file:/app_8_3_4_4.xml");
啦啦啦
啦啦啦
8 -- 深入使用Spring -- 3...4 在ApplicationContext中使用资源的更多相关文章
- Spring配置文件详解 – applicationContext.xml文件路径
Spring配置文件详解 – applicationContext.xml文件路径 Java编程 spring的配置文件applicationContext.xml的默 ...
- 获取Spring的上下文环境ApplicationContext的方式
摘自: http://blog.csdn.net/yang123111/article/details/32099329 获取Spring的上下文环境ApplicationContext的方式 Web ...
- 【Spring】23、ApplicationContext ,ApplicationContextAware,Listener,Event 的关系解读
tomcat容器启动流程 启动tomcat容器,加载web.xml,建立整个容器(Servlet容器,这里是tomcat吧)的上下文,ServletContext,这时web.xml有个监听器,就是C ...
- spring ApplicationContext中Bean的生命周期
AbstractApplicationContext Spring的AbstractApplicationContext是ApplicationContext的抽象实现类,该抽象类的refresh方法 ...
- spring BeanFactory及ApplicationContext中Bean的生命周期
spring bean 的生命周期 spring BeanFactory及ApplicationContext在读取配置文件后.实例化bean前后.设置bean的属性前后这些点都可以通过实现接口添加我 ...
- 7 -- Spring的基本用法 -- 4... 使用 Spring 容器:Spring 容器BeanFactory、ApplicationContext;ApplicationContext 的国际化支持;ApplicationContext 的事件机制;让Bean获取Spring容器;Spring容器中的Bean
7.4 使用 Spring 容器 Spring 有两个核心接口:BeanFactory 和 ApplicationContext,其中ApplicationContext 是 BeanFactory ...
- Spring之BeanFactory与ApplicationConText区别
使用BeanFactory从xml配置文件加载bean: import org.springframework.beans.factory.xml.XmlBeanFactory; import org ...
- 【转】Spring总结以及在面试中的一些问题
[转]Spring总结以及在面试中的一些问题. 1.谈谈你对spring IOC和DI的理解,它们有什么区别? IoC Inverse of Control 反转控制的概念,就是将原本在程序中手动创建 ...
- ApplicationContext中Bean的生命周期
引言 Bean应用上下文中的生命周期和在BeanFactory中生命周期类似,不同的是,如果Bean实现了org.springframework.context.ApplicationContextA ...
随机推荐
- android开发(38) 使用 DrawerLayou t实现左侧抽屉式导航菜单
最近流行 左侧抽屉式的导航条菜单,知乎,360,QQ都使用了这样的导航菜单,我们也了解下: Android Design 的流行趋势:Navigation Drawer 导航抽屉 参考这篇文章:htt ...
- SpringBoot2 全局异常处理
参考这篇文章里面的几种异常形式: 全局异常处理是个比较重要的功能,一般在项目里都会用到. 大概把一次请求分成三个阶段,来分别进行全局的异常处理. 一:在进入Controller之前,譬如请求一个不存在 ...
- eclipse配置google代码风格
1.下载google code style的xml文件 地址:https://github.com/google/styleguide 导入xml文件 可能会遇到警告: 版本的问题,忽略即可. < ...
- const_cast的应用
对于const变量,我们不能修改它的值,这是这个限定符最直接的表现.但是我们就是想违背它的限定希望修改其内容怎么办呢?于是我们可以使用const_cast转换符是用来移除变量的const限定符.con ...
- Java设计模式(9)适配器模式(Adapter模式)
适配器模式定义:将两个不兼容的类纠合在一起使用,属于结构型模式,需要有Adaptee(被适配者)和Adaptor(适配器)两个身份. 为何使用适配器模式 我们经常碰到要将两个没有关系的类组合在一起使用 ...
- 用stringr包处理字符串
<Machine Learning for Hackers>一书的合著者John Myles White近日接受了一个访谈.在访谈中他提到了自己在R中常用的几个扩展包,其中包括用ggplo ...
- 安卓程序代写 网上程序代写[原]BluetoothDevice详解
一. BluetoothDevice简介 1. 继承关系 public static Class BluetoothDevice extends Object implement Parcelable ...
- css之-webkit-scrollbar
在IE中可以自定义滚动条的样式 ,基于webkit的浏览器现在也可以自定义其样式: ::-webkit-scrollbar { /* 1 */ } ::-webkit-s ...
- Qt中使用的C++知识和技能-你必须要了解的
如果你不确定在使用Qt编程时自己所掌握的C++知识是否够用,这一节的内容会帮到你.这里给出了Qt自身以及在使用Qt进行编程时涉及到的C++知识,因此,通过阅读本节,你会了解你是否缺少一些C++技能. ...
- Android 8 AudioPolicy 分析
AudioTrack最终会调用AudioPolicyManager::getOutput(); frameworks\av\services\audiopolicy\managerdefault\Au ...