Spring中两种引入配置文件方式
用过Spring的人都知道,我们一般把数据库的配置、日志的配置或者其他的通用配置放在单独的配置文件中,在和Spring整合时,一般通过以下两种方法引入:
- <context:property-placeholder>
- <util:properties>
下面我们来对比一下这两种方法。
<context:property-placeholder>
-
首先,这个是Spring中context下对应的一个标签。要使用它需要在Spring的配置文件头部中引入其对应的命名空间。
-
其使用方式也很简单
<context:property-placeholder location="classpath:db.properties" /> <!-- 引入配置文件 –>
<!--该标签对应的属性有:
location : 所需要引入的配置文件,当有多个时,可以使用逗号分开。项目里的配置文件一般在类路径下,所以可以使用classpath:xxx
order :一般我们可能会使用多个context:property-placeholder标签引入多个配置文件,order这个属性可以控制配置文件加载的顺序,order数字越低越先加载
ignore-resource-not-found :boolean值,可以控制是否忽略引入的文章找不到的情况,为true代表忽略,当引入文件不存在时,不会报错
properties-ref : 除了引入文件外,还可以引入本地定义的配置对象
local-ovriride : boolean值,控制是否properties-ref覆盖location中的属性值
-->
通过上面的方法就在Spring中引入了该配置文件。其使用方式是通过$,例如:${xxx}。在Spring xml中可以使用${xxx},在java代码中可以使用@Value(“${xxx}”),类似于
<property name="url" value="${mysql.jdbc.url}" />
@Value("${mysql.jdbc.url}")
private String mysqlJdbcUrl;
<util:properties>
- 其实Spring中util下的一个标签。使用它需要引入util的命名空间。
- 使用方法也很简单
<util:properties id="wxProperties" location="classpath:wx.properties" />
<!--
id :该配置文件对象名称,可以通过该名称引用配置文件中的属性 location : 和上面的标签的location属性类似 -->
配置完成后,可以在java类中使用,使用方式: @Value("#{wxProperties['jdbc.driver']}") ,类似于
@Value("#{wxProperties['jdbc.driver']}") private String jdbcDriver;
区别
<context:property-placeholder> 定义的变量只能够在其对应的上下文中使用
<util:properties>在整个Spring中都能使用
之前做一个项目时,由于没有发现这两个的区别,混用了这两个标签,最后导致了一部分定义在<context:property-placeholder>的变量无法使用。原因就是其只能作用在对应的上下文中,而我们使用该变量的位置不在其上下文中,最后导致了null。解决方法就是1.使用第二个标签;2.在我们使用的变量的地方引入<context:property-placeholder>