今天想把xml里面的一些值移到properties文件里方便修改,按照标准的做法,在xml文件的开头加上这么一段:
<bean
class="org.springframework.beans.factory.config.PropertyPlaceholderConfigurer"
lazy-init="true">
<property name="locations">
<list>
<value>classpath:db.properties</value>
</list>
</property>
</bean>
但是情况有点特殊,我使用的是一个框架,它会调用Spring的类来加载xml文件。它首先加载a.xml文件,然后a.xml会引用b.xml文件,b.xml里面有一些占位符需要用到db.properties里面的value来替换。设置好以后重启,发现b.xml里面的占位符没有被替换的,怎么改都没用。
后来观察log发现这个框架是使用XmlBeanFactory来加载这些xml文件的,因为日志里有如下的一些信息:
(XmlBeanDefinitionReader.java:323) INFO - Loading XML bean definitions from class path resource
因为按照平常自己的习惯,我会用ClassPathXmlApplicationContext来加载xml文件,难道这两者还有什么区别不成,查了一下资料,果然存在不同,ApplicationContext被推荐使用,因为它包含了很多BeanFactory没有的功能:
Table 3.5. Feature Matrix
Feature | BeanFactory | ApplicationContext |
---|---|---|
Bean instantiation/wiring | Yes | Yes |
Automatic BeanPostProcessor registration | No | Yes |
Automatic BeanFactoryPostProcessor registration | No | Yes |
Convenient MessageSource access (for i18n) | No | Yes |
ApplicationEvent publication | No | Yes |
http://static.springsource.org/spring/docs/2.5.x/reference/beans.html#context-introduction-ctx-vs-beanfactory