Spring的properties解析【context:property-placeholder】

本文介绍如何使用Spring的PropertyPlaceholderConfigurer及PropertySourcesPlaceholderConfigurer进行属性占位符的配置与解析,包括不同版本间的差异及高级用法。

转自:http://www.cnblogs.com/beiyeren/p/3488871.html


一般使用PropertyPlaceholderConfigurer来替换占位符,例如:

<bean class="org.springframework.beans.factory.config.PropertyPlaceholderConfigurer">
  <property name="locations">
      <value>classpath:com/foo/strategy.properties</value>
  </property>
  <property name="properties">
      <value>custom.strategy.class=com.foo.DefaultStrategy</value>
  </property>
</bean>

spring 2.5之后,可以使用

<context:property-placeholder location="classpath:com/foo/jdbc.properties"/>

其本质是注册了一个PropertyPlaceholderConfigurer(3.1之前)或者是PropertySourcesPlaceholderConfigurer(3.1之后)

Tip:

 

PropertyPlaceholderConfigurer内置的功能非常丰富,如果它未找到${xxx}中定义的xxx键,它还会去JVM系统属性(System.getProperty())和环境变量(System.getenv())中寻找。通过启用systemPropertiesMode和searchSystemEnvironment属性,开发者能够控制这一行为。

而PropertySourcesPlaceholderConfigurer在此基础上会和Environment and PropertySource配合更好。

另外需要注意以下几点

1、在PropertyPlaceholderBeanDefinitionParser的父类中shouldGenerateId返回true,即默认会为每一个bean生成一个唯一的名字; 如果使用了两个<context:property-placeholder则注册了两个PropertySourcesPlaceholderConfigurer Bean;所以不是覆盖(而且bean如果同名是后边的bean定义覆盖前边的); 
2、PropertySourcesPlaceholderConfigurer本质是一个BeanFactoryPostProcessor,spring实施时如果发现这个bean实现了Ordered,则按照顺序执行;默认无序; 
3、此时如果给<context:property-placeholder加order属性,则会反应出顺序,值越小优先级越高即越早执行; 
比如 
   <context:property-placeholder order="2" location="classpath*:conf/conf_a.properties"/>  
   <context:property-placeholder order="1" location="classpath*:conf/conf_b.properties"/> 
此时会先扫描order='1' 的,如果没有扫描order='2'的 
4、默认情况下ignore-unresolvable;即如果没找到的情况是否抛出异常。默认false:即抛出异常; 
<context:property-placeholder location="classpath*:conf/conf_a.properties" ignore-unresolvable="false"/>

<think>我们正在处理一个关于Spring框架中`<context:property-placeholder>`的用法和配置问题。根据用户需求,我们需要提供清晰的结构化回答,并确保使用正确的中文和LaTeX格式。首先,回顾引用内容:-引用[1]提到SpringBoot默认配置了`PropertySourcesPlaceholderConfigurer`,从`application.properties`和`application.yml`获取属性。-引用[2]提到Spring提供了一个默认的宽松嵌入式值解析器,如果无法解析则注入属性名;要严格控制不存在的值,需要声明`PropertySourcesPlaceholderConfigurer`。-引用[3]展示了`resolvePlaceholders()`方法如何通过`propertyResolver`解析占位符。用户的问题是关于SpringXML配置中的`<context:property-placeholder>`,它用于在XML配置文件解析属性占位符(如`${property.name}`)。###回答结构1.**介绍**:解释`<context:property-placeholder>`的作用。2.**基本配置**:展示基本用法和常用属性。3.**属性详解**:解释关键属性(如`location`、`ignore-resource-not-found`等)。4.**注意事项**:包括与SpringBoot的自动配置的对比以及多个配置的处理。5.**示例**:给出一个完整的配置示例。###生成相关问题根据主题,生成3个相关问题。###开始回答</think>### Spring context:property-placeholder 用法与配置 `<context:property-placeholder>` 是 Spring 框架中用于外部化配置的核心 XML 元素,它通过 `PropertySourcesPlaceholderConfigurer` 实现属性占位符解析(如 `${db.url}`)。以下是详细说明: #### 1. **核心作用** - **占位符解析**:在 XML 或注解配置中解析 `${...}` 格式的属性值,例如: ```xml <bean class="com.example.DataSource"> <property name="url" value="${db.url}"/> </bean> ``` - **外部化配置**:将属性值从代码分离到外部文件(如 `.properties`),便于环境切换[^1]。 #### 2. **基础配置** ```xml <context:property-placeholder location="classpath:db.properties,file:/etc/app/config.properties" ignore-resource-not-found="true" ignore-unresolvable="true" system-properties-mode="OVERRIDE" /> ``` - **`location`**:属性文件路径,支持多个文件(逗号分隔)和通配符(`classpath*:/config/*.properties`)。 - **`ignore-resource-not-found`**:是否忽略缺失文件(默认 `false`,缺失时报错)。 - **`ignore-unresolvable``**:是否忽略无法解析的占位符(默认 `false`,未匹配时报错)。 - **`system-properties-mode`**:系统属性优先级(`ENVIRONMENT`/`OVERRIDE`/`NEVER`)。 #### 3. **关键机制** - **解析顺序**:按 `location` 顺序加载属性,后加载的值覆盖先加载的值。 - **宽松模式**:默认行为下,未解析的占位符(如 `${unknown}`)会直接注入原始字符串。需显式设置 `ignore-unresolvable="false"` 强制严格校验[^2]。 - **与 Spring Boot 区别**:Spring Boot 自动配置 `PropertySourcesPlaceholderConfigurer`,优先从 `application.properties` 加载[^1]。XML 配置需手动声明。 #### 4. **高级配置** 若需完全控制解析行为,可显式定义 `PropertySourcesPlaceholderConfigurer` bean: ```xml <bean class="org.springframework.context.support.PropertySourcesPlaceholderConfigurer"> <property name="locations"> <list> <value>classpath:default.properties</value> <value>file:${CONF_DIR}/override.properties</value> </list> </property> <property name="ignoreUnresolvablePlaceholders" value="true"/> <property name="valueSeparator" value=":"/> <!-- 修改占位符分隔符为 ${key:default} --> </bean> ``` - **自定义占位符**:通过 `setPlaceholderPrefix`/`setPlaceholderSuffix` 修改 `${` 和 `}` 符号。 - **默认值支持**:使用 `:` 指定默认值,如 `${db.port:3306}`[^1]。 #### 5. **注意事项** - **避免重复声明**:多个 `<context:property-placeholder>` 会导致解析冲突,应合并配置。 - **Profile 支持**:结合 Spring Profiles 可环境差异化加载属性: ```xml <context:property-placeholder location="classpath:config-${spring.profiles.active}.properties"/> ``` - **加密属性**:需集成工具(如 Jasypt)解密 `${cipher:ENCRYPTED_VALUE}` 格式的值。 > **示例属性文件** (`db.properties`): > ``` > db.url=jdbc:mysql://localhost:3306/mydb > db.user=admin > db.password=secret > ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值