spring中context:property-placeholder/元素

本文介绍Spring框架中如何使用context:property-placeholder元素和PropertyPlaceholderConfigurer实现参数的外在化配置,便于在不同开发阶段灵活切换参数配置。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

转自:http://blog.sina.com.cn/s/blog_4550f3ca0100ubmt.html
1.有些参数在某些阶段中是常量
比如 :a、在开发阶段我们连接数据库时的连接url,username,password,driverClass等
b、分布式应用中client端访问server端所用的server地址,port,service等
c、配置文件的位置
2.而这些参数在不同阶段之间又往往需要改变
比如:在项目开发阶段和交付阶段数据库的连接信息往往是不同的,分布式应用也是同样的情况。
期望:能不能有一种解决方案可以方便我们在一个阶段内不需要频繁书写一个参数的值,而在不同阶段间又可以方便的切换参数配置信息
解决:spring3中提供了一种简便的方式就是context:property-placeholder/元素
只需要在spring的配置文件里添加一句: 即可,这里location值为参数配置文件的位置,参数配置文件通常放在src目录下,而参数配置文件的格式跟java通用的参数配置文件相同,即键值对的形式,例如:

jdbc配置

test.jdbc.driverClassName=com.mysql.jdbc.Driver
test.jdbc.url=jdbc:mysql://localhost:3306/test
test.jdbc.username=root
test.jdbc.password=root
行内#号后面部分为注释
应用:
1.这样一来就可以为spring配置的bean的属性设置值了,比如spring有一个jdbc数据源的类DriverManagerDataSource
在配置文件里这么定义bean:





2.甚至可以将${ }这种形式的变量用在spring提供的注解当中,为注解的属性提供值

外在化应用参数的配置

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

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

如下内容摘自propertyplaceholderconfigurer.xml。正常情况下,在userInfo的定义中不会出现 db.username {db.password}等类似信息,这里采用PropertyPlaceholderConfigurer管理username和password属性的取值。DI容器实例化userInfo前,PropertyPlaceholderConfigurer会修改userInfo的元数据信息(定义),它会用userinfo.properties中db.username对应的scott值替换 db.usernamedb.passwordtiger {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提供了元素。下面给出了配置示例,启用它后,开发者便不用配置PropertyPlaceholderConfigurer对象了。


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 > ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值