spring中context:property-placeholder/元素

外在化配置参数
本文介绍如何使用Spring框架中的PropertyPlaceholderConfigurer实现应用参数的外在化管理,通过配置文件userinfo.properties来动态设置数据库连接信息。

外在化应用参数的配置

在开发企业应用期间,或者在将企业应用部署到生产环境时,应用依赖的很多参数信息往往需要调整,比如LDAP连接、RDBMS JDBC连接信息。对这类信息进行外在化管理显得格外重要。PropertyPlaceholderConfigurer和PropertyOverrideConfigurer对象,它们正是担负着外在化配置应用参数的重任。

  <context:property-placeholder/>元素

PropertyPlaceholderConfigurer实现了BeanFactoryPostProcessor接口,它能够对<bean/>中的属性值进行外在化管理。开发者可以提供单独的属性文件来管理相关属性。比如,存在如下属性文件,摘自userinfo.properties。
db.username=scott
db.password=tiger

如下内容摘自propertyplaceholderconfigurer.xml。正常情况下,在userInfo的定义中不会出现${db.username}、${db.password}等类似信息,这里采用PropertyPlaceholderConfigurer管理username和password属性的取值。DI容器实例化userInfo前,PropertyPlaceholderConfigurer会修改userInfo的元数据信息(<bean/>定义),它会用userinfo.properties中db.username对应的scott值替换${db.username}、db.password对应的tiger值替换${db.password}。最终,DI容器在实例化userInfo时,UserInfo便会得到新的属性值,而不是${db.username}、${db.password}等类似信息。

<bean id="propertyPlaceholderConfigurer" class="org.springframework.beans.factory.config.PropertyPlaceholderConfigurer">  
    	<property name="locations">  
    	    <list>  
     	       <value>userinfo.properties</value>  
    	    </list>  
  	  </property>  
    </bean>  
<bean name="userInfo" class="test.UserInfo">  
<property name="username" value="${db.username}"/> <property name="password" value="${db.password}"/>
</bean> 

  通过运行并分析PropertyPlaceholderConfigurerDemo示例应用,开发者能够深入理解PropertyPlaceholderConfigurer。为简化PropertyPlaceholderConfigurer的使用,Spring提供了<context:property-placeholder/>元素。下面给出了配置示例,启用它后,开发者便不用配置PropertyPlaceholderConfigurer对象了。

<context:property-placeholder location="userinfo.properties"/>

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

<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 > ```
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值