`

Spring(12)——PropertyPlaceholderConfigurer

阅读更多

12 PropertyPlaceholderConfigurer

PropertyPlaceholderConfigurer是对BeanFactoryPostProcessor接口的一种实现,其允许我们在定义bean的时候将bean的某些属性定义为变量形式,然后由PropertyPlaceholderConfigurer在这些bean被实例化之前利用外部定义的属性文件或者其内部定义的属性等将这些变量替换成对应的属性值。

我们可能经常会见到或者用到这样的定义,context:property-placeholder是Spring context命名空间内置的一个标签,针对该标签Spring内部会建立一个PropertyPlaceholderConfigurer对应的bean,其中location属性表示需要加载的外部属性文件对应的路径。

<context:property-placeholder location="/WEB-INF/config/jdbc.properties" />

<bean id="dataSource" class="org.apache.commons.dbcp2.BasicDataSource"
	destroy-method="close">
	<property name="driverClassName" value="${jdbc.driverClassName}" />
	<property name="url" value="${jdbc.url}" />
	<property name="username" value="${jdbc.username}" />
	<property name="password" value="${jdbc.password}" />
</bean>

我们可以看到在上述配置中,id为dataSource的bean对应的属性值我们都是用的变量表示的。我们定义的PropertyPlaceholderConfigurer将在所有bean初始化前利用我们定义的外部属性文件jdbc.properties来对这些变量进行替换,所以对应的值我们可以直接定义在jdbc.properties文件中。

jdbc.driverClassName=oracle.jdbc.driver.OracleDriver
jdbc.url=jdbc:oracle:thin:@localhost:1521:orcl
jdbc.username=crm
jdbc.password=crm

我们可以在bean容器中直接定义一个PropertyPlaceholderConfigurer类型的bean,用以在所有的bean定义加载完成后利用其可用的属性替换bean定义中使用的变量。PropertyPlaceholderConfigurer和PropertySourcesPlaceholderConfigurer均是继承自抽象类PlaceholderConfigurerSurpport的,它们使用的变量替换的主逻辑均来自PlaceholderConfigurerSurpport。

12.1 可用来作为替换变量的属性

12.1.1 外部属性文件

PropertyPlaceholderConfigurer常用来替换变量的属性通常是来自外部属性文件定义,通过其setLocation()方法或者是setLocations()方法进行注入,其中setLocation()方法用来注入一个外部属性文件,而setLocations()则是用来注入一个或多个外部属性文件,在注入的时候它们都将会被作为一个Resource进行注入。

通过setLocation()注入单个属性文件。

	<bean class="org.springframework.beans.factory.config.PropertyPlaceholderConfigurer">
<!-- 		通过setLocation()方法指定单个外部属性文件的位置 -->
		<property name="location" value="classpath:t1.properties"/>
	</bean>

通过setLocations()注入一个或多个属性文件。

	<bean class="org.springframework.beans.factory.config.PropertyPlaceholderConfigurer">
		<!-- 通过setLocations()方法指定一到多个外部属性文件的位置 -->
		<property name="locations">
			<array>
				<value>classpath:t1.properties</value>
				<value>classpath:t2.properties</value>
			</array>
		</property>
	</bean>

12.1.2 内部属性

内部属性是通过setProperties()或setPropertiesArray()方法进行定义的,其中前者接收一个Properties对象,而后者则是接收一个Properties数组。

	<bean class="org.springframework.beans.factory.config.PropertyPlaceholderConfigurer">
		<!-- 直接通过setProperties()方法定义属性 -->
		<property name="properties">
			<props>
				<prop key="p1">v1</prop>
				<prop key="p2">v2</prop>
			</props>
		</property>
	</bean>

12.1.3环境变量、系统变量

环境变量、系统变量是可以直接被PropertyPlaceholderConfigurer用来作为属性源对bean定义中使用的变量进行替换的。如JAVA_HOME、user.dir等。环境变量即通过System.getenv(name)可获取到的,而系统变量则表示指定的JVM参数,即通过System.getProperty(name)可获取到的。

12.1.4 属性来源优先级

既然我们可以用来替换变量的属性来源有多种不同的方式,那么当其中两者存在冲突时将采取怎样的策略呢?
外部属性文件定义和内部属性定义算是一类,这里我们把它定义为A类,环境变量和系统变量定义为B类。在A类里面当外部属性文件中的定义与内部属性的定义存在冲突,即存在相同的属性时,默认情况下是外部属性文件定义的属性值将覆盖内部properties定义的。如果需要设置内部属性定义将覆盖外部属性文件定义的属性,则可以通过setLocalOverride()方法指定对应的localOverride为true来达到设置内部属性定义覆盖外部属性文件定义的属性的目的。

	<!-- 通过setLocalOverride()方法设置内部属性定义将覆盖外部属性文件的定义 -->
	<bean
		class="org.springframework.beans.factory.config.PropertyPlaceholderConfigurer"
		p:localOverride="true">
		
	</bean>

对于B类存在与A类相同的属性定义时,将采取何种策略也是根据一个参数来确定的。通过setSystemPropertiesMode()方法可以指定对应的值,也可以通过setSystemPropertiesModeName()来指定对应的策略名称。其中可选值和可选名称如下:

  • SYSTEM_PROPERTIES_MODE_NEVER:对应值为0。表示不使用系统属性进行替换。
  • SYSTEM_PROPERTIES_MODE_FALLBACK:对应的值为1,这是默认选项。表示只有在A类属性中没有找到变量对应的属性时才会尝试使用系统属性来进行替换。
  • SYSTEM_PROPERTIES_MODE_OVERRIDE:对应的值为2。表示当系统属性存在变量对应的属性时将使用系统属性的值。
	<!-- 指定系统属性将具有最高优先级 -->
	<bean
		class="org.springframework.beans.factory.config.PropertyPlaceholderConfigurer"
		p:systemPropertiesMode="2">
		<property name="properties">
			<props>
				<prop key="java.tempdir">abc</prop>
			</props>
		</property>
	</bean>

12.2 变量的定义

变量默认是使用“${varName}”的形式进行定义的,即以“${”开始,以“}”结束,中间对应变量名,PropertyPlaceholderConfigurer默认会将这种形式的定义当做是需要进行替换的变量定义,中间对应的是变量名。基本上除了id和name以外,bean定义的其它内容都可以使用变量进行定义,如class、parent等。

	<!-- 将userDir定义为一个需要替换的变量user.dir -->
	<bean id="hello" class="com.app.Hello" p:userDir="${user.dir}"/>	

以上就是一个将属性userDir定义为变量user.dir的示例,在bean该bean被实例化之前将会由定义的PropertyPlaceholderConfigurer将其中的变量${user.dir}进行替换。如果我们不想变量定义为“${varName}”的形式我们也可以通过setPlaceholderPrefix()方法来指定变量对应的前缀,默认是“${”,然后通过setPlaceholderSuffix()方法来指定对应的后缀,默认是“}”。所以如果我们希望我们的变量定义为“@{varName}”的形式,我们可以如下定义:

	<!-- 指定变量的前缀为“@{”,后缀为“}” -->
	<bean
		class="org.springframework.beans.factory.config.PropertyPlaceholderConfigurer"
		p:placeholderPrefix="@{" p:placeholderSuffix="}" />

那么对应的变量就可以定义成如下这样:

	<!-- 将userDir定义为一个需要替换的变量user.dir -->
	<bean id="hello" class="com.app.Hello" p:userDir="@{user.dir}" />
</beans>

12.3 指定默认值

我们还可以在定义属性变量时指定对应的默认值。如果指定了属性变量的默认值,则在未找到可用于替换当前属性变量的属性时将使用定义好的默认值来替换当前属性变量。我们在定义属性变量时在变量名后面紧接着就可以指定默认值,默认值与变量名之间以分号隔开,形式如:${varName:defValue},其中varName表示变量名,defValue表示默认值。

	<!-- 指定属性变量maxVal的默认值为100 -->
	<bean id="hello" class="com.app.Hello" p:maxVal="${maxVal:100}" />

属性变量名与默认值之间的分隔符默认是分号“:”,如果有需要用户也可以通过PropertyPlaceholderConfigurer的setValueSeparator()方法进行修改。

	<bean class="org.springframework.beans.factory.config.PropertyPlaceholderConfigurer"> 
		<!-- 指定属性变量名与默认值之间的分隔符为两个分号 -->
		<property name="valueSeparator" value="::"/>
	</bean>

12.4 忽略文件未找到

默认情况下我们在通过setLocation()或setLocations()方法指定外部属性文件时,如果对应的文件不存在将抛出异常信息。通过setIgnoreResourceNotFound()方法我们可以设置是否忽略文件未找到的情况,默认为false,即抛出异常信息。如果用户希望忽略对应的错误,则可以设置对应的值为null。

	<bean class="org.springframework.beans.factory.config.PropertyPlaceholderConfigurer"> 
		<property name="location" value="classpath:t12.properties"/> 
		<!-- 指定当外部属性文件不存在时不抛出异常 -->
		<property name="ignoreResourceNotFound" value="true"/>
	</bean>

12.5 忽略变量不能解析

默认情况下PropertyPlaceholderConfigurer会把bean定义中所有${varName}形式的定义都当做是一个属性变量定义进行替换。当bean定义中存在形式为${varName}的变量定义但是又不能被PropertyPlaceholderConfigurer利用定义的外部属性文件包含的属性或内部属性定义的属性或环境变量进行替换时,其会抛出异常信息。如果希望在对应的属性变量不能被解析时不抛出异常信息,则可以通过setIgnoreUnresolvablePlaceholders()方法指定ignoreUnresolvablePlaceholders的值为true,这样就将忽略变量不能被解析的情况。

 

	<bean class="org.springframework.beans.factory.config.PropertyPlaceholderConfigurer"> 
		<property name="location" value="classpath:t12.properties"/> 
		<!-- 指定当外部属性文件不存在时不抛出异常 -->
		<property name="ignoreResourceNotFound" value="true"/>
		<!-- 忽略变量不能被解析的情况 -->
		<property name="ignoreUnresolvablePlaceholders" value="true"/>
	</bean>

 

 

本文转自:https://elim.iteye.com/blog/2387138

分享到:
评论

相关推荐

    Spring如何使用PropertyPlaceholderConfigurer读取文件

    Spring如何使用PropertyPlaceholderConfigurer读取文件 Spring框架中,PropertyPlaceholderConfigurer是一个非常重要的组件,它可以帮助我们读取配置文件,实现系统的配置信息统一管理。在大型项目中,我们往往会将...

    Spring中PropertyPlaceholderConfigurer的使用

    Spring 中 PropertyPlaceholderConfigurer 的使用 PropertyPlaceholderConfigurer 是 Spring 框架中的一个重要组件,用于加载和管理 Properties 文件。它能够将 Properties 文件中的键值对注入到 Spring 的 bean 中...

    Spring属性占位符PropertyPlaceholderConfigurer的使用

    在Spring框架中,属性占位符`PropertyPlaceholderConfigurer`是一个重要的工具,用于处理配置文件中的属性值引用。它使得我们可以在XML配置文件中使用占位符`${...}`来引用外部属性文件中的值,从而使应用配置更加...

    Spring PropertyPlaceholderConfigurer配置文件加载器集成ZooKeeper来实现远程配置读取

    在Spring中,`PropertyPlaceholderConfigurer`是一个非常重要的类,它用于处理属性文件中的占位符,将它们替换为实际的值。这在配置管理中起到了关键作用,特别是在大型分布式系统中,动态配置管理变得尤为重要。...

    org.springframework.beans.factory.config.PropertyPlaceholderConfigurer

    `org.springframework.beans.factory.config.PropertyPlaceholderConfigurer` 是Spring框架中的一个重要组件,主要负责处理配置文件中的占位符替换。这个类是Spring在初始化bean时用来解析和注入环境变量或系统属性...

    关于spring系统中多系统的配置

    在Spring框架中,`PropertyPlaceholderConfigurer`是一种特殊的Bean,它被用来处理Spring配置文件中的占位符(placeholder),并将它们替换为具体的值。这些值通常来自外部的属性文件,如`.properties`或`.xml`等。...

    SSM框架——详细整合教程(Spring+SpringMVC+MyBatis)

    ### SSM框架——详细整合教程(Spring+SpringMVC+MyBatis) #### Spring框架概述 Spring 是一个轻量级的开源Java应用框架,最初由Rod Johnson在其著作《Expert One-On-One J2EE Development and Design》中提出。...

    Spring动态加载配置文件

    `PropertyPlaceholderConfigurer`是Spring早期版本中处理属性文件的工具,而`@PropertySource`则是从Spring 3.1引入的新特性,它们都可以用来从外部属性文件中读取值并注入到bean中。 1. `...

    java 获取properties的几种方式(csdn)————程序.pdf

    例如,Spring的`PropertyPlaceholderConfigurer`和`&lt;context:property-placeholder&gt;`适用于Spring应用,而`ResourceBundle`适合处理本地化,`Properties`类则是一个通用解决方案。理解并熟练掌握这些方法,将有助于...

    Spring-Reference_zh_CN(Spring中文参考手册)

    PropertyPlaceholderConfigurer示例 3.7.2.2. PropertyOverrideConfigurer示例 3.7.3. 使用FactoryBean定制实例化逻辑 3.8. ApplicationContext 3.8.1. 利用MessageSource实现国际化 3.8.2. 事件 3.8.3. 底层资源的...

    SPRING:bean配置properties

    在Spring框架中,Bean的配置与管理是其核心功能之一,而通过`PropertyPlaceholderConfigurer`进行属性占位符的配置则是实现动态配置的关键技术。本文将深入解析如何利用`PropertyPlaceholderConfigurer`进行bean配置...

    Spring 容器后处理器

    &lt;bean id="propertyConfigurer" class="org.springframework.beans.factory.config.PropertyPlaceholderConfigurer"&gt; &lt;value&gt;classpath:application.properties ``` 在这个示例中,`...

    spring2.5 hibernate3.2 事务

    标题中的“spring2.5 hibernate3.2 事务”涉及到的是两个关键的Java开发框架——Spring和Hibernate,以及它们在处理事务管理方面的整合。Spring是面向切面编程(AOP)的轻量级框架,提供了强大的事务管理功能;...

    Spring MVC 入门实例

    6 &lt;bean id="propertyConfigurer" class="org.springframework.beans.factory.config.PropertyPlaceholderConfigurer"&gt; 7 8 9 &lt;value&gt;/WEB-INF/jdbc.properties 10 11 12 13 14 它配置了以下功能: 读取...

    spring2.5 配置VM

    &lt;bean id="propertyConfigurer" class="org.springframework.beans.factory.config.PropertyPlaceholderConfigurer"&gt; &lt;value&gt;classpath:db.properties ${jdbc.driver}" /&gt; ${jdbc.url}" /&gt; ${jdbc....

    Spring数据库连接等配置加密

    在IT行业中,尤其是在开发企业级应用时,...Spring提供了`PropertyPlaceholderConfigurer`和`EncryptablePropertyPlaceholderConfigurer`来实现这个功能。首先,我们需要创建一个解密器类,如下所示: ```xml ...

    Spring项目中怎么配置log4j

    在Spring项目中,我们可以使用Spring的`PropertyPlaceholderConfigurer`来加载外部化的log4j配置,这样在不同环境中可以使用不同的配置文件。在Spring的配置文件`applicationContext.xml`中添加以下代码: ```xml ...

    spring

    - **PropertyPlaceholderConfigurer** 和 **PropertyOverrideConfigurer**:用于在运行时动态替换Bean配置中的占位符。 ### 结论 Spring框架以其强大的功能和灵活性,成为Java企业级应用开发的首选框架之一。通过...

    spring4.0引用properties

    `PropertyPlaceholderConfigurer`是Spring早期版本中用于注入properties文件中值的bean,而`@ConfigurationProperties`是Spring Boot引入的,更适合现代Spring应用。 使用`PropertyPlaceholderConfigurer`的例子...

    spring源码经典实例

    2. **配置文件改进**:将`jdbc.properties`移动到合适的位置,如`src/main/resources`,并使用Spring的`PropertyPlaceholderConfigurer`或者`@Value`注解读取配置,以实现数据库连接参数的动态加载。 3. **使用...

Global site tag (gtag.js) - Google Analytics