Spring(13)——PropertyPlaceholderConfigurer

13 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。

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

13.1.1 外部属性文件

PropertyPlaceholderConfigurer常用来替换变量的属性通常是来自外部属性文件定义,通过其setLocation()方法或者是set

  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Spring Boot中,可以通过自定义一个PropertySource来实现自定义的PropertyPlaceholderConfigurer。 首先,创建一个类,继承自PropertySource,实现getProperties方法,该方法返回一个Properties对象,其中包含了我们要替换的属性值,例如: ```java public class MyPropertySource extends PropertySource { public MyPropertySource(String name) { super(name); } @Override public Object getProperty(String name) { // 返回我们要替换的属性值 if (name.equals("my.property")) { return "my custom property value"; } return null; } @Override public boolean containsProperty(String name) { // 判断是否包含我们要替换的属性 return name.equals("my.property"); } @Override public Enumeration<?> getPropertyNames() { // 返回所有属性名 return Collections.enumeration(Arrays.asList("my.property")); } @Override public String toString() { return "MyPropertySource"; } } ``` 然后,在Spring Boot启动类中,将该自定义的PropertySource添加到Environment中: ```java @SpringBootApplication public class MyApp { public static void main(String[] args) { SpringApplication app = new SpringApplication(MyApp.class); app.setAdditionalProfiles("my-profile"); app.setEnvironment(new StandardEnvironment() { @Override protected void customizePropertySources(MutablePropertySources propertySources) { super.customizePropertySources(propertySources); propertySources.addFirst(new MyPropertySource("my-property-source")); } }); app.run(args); } } ``` 在上述代码中,我们通过setEnvironment方法设置了一个新的Environment,并在customizePropertySources方法中,将自定义的PropertySource添加到了最前面,以确保优先使用该自定义的PropertySource替换属性值。 最后,在application.yml或application.properties中,可以使用${my.property}来引用我们自定义的属性值,例如: ```yaml my.custom.property: ${my.property} ``` 这样,当应用启动时,就会将${my.property}替换成我们自定义的属性值"my custom property value"。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值