zoukankan      html  css  js  c++  java
  • spring 使用 context:property-placeholder 加载 多个 properties

    一般使用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="0" location="classpath:dbconfig.properties"/>  
       <context:property-placeholder order="1" location="classpath*:conf/conf_a.properties"/>  
       <context:property-placeholder order="2" 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"/>

  • 相关阅读:
    静态切割窗体+关联对话框
    POJ 2236 Wireless Network(并查集)
    怎样学习(3):迭代学习,精益求精
    【菜鸟也疯狂UML系列】——概述
    OpenGL 资源汇编
    vue之mapMutaions的使用 && vuex中 action 用法示例 && api.js的使用
    内置组件 && vue中强大的缓存机制之keep-alive
    vue生命周期及使用 && 单文件组件下的生命周期
    vue中遇到的坑 --- 变化检测问题(数组相关)
    如何去除vue项目中的 # --- History模式
  • 原文地址:https://www.cnblogs.com/a393060727/p/5066506.html
Copyright © 2011-2022 走看看