Spring boot中的注解@ConditionalOnProperty,可以通过配置文件中的属性值来判定configuration是否被注入,
@Retention(RetentionPolicy.RUNTIME)
@Target({ ElementType.TYPE, ElementType.METHOD })
@Documented
@Conditional(OnPropertyCondition.class)
public @interface ConditionalOnProperty {
   /**
   * String数组  该属性与下面的 name 属性不可同时使用,
    * 当value所对应配置文件中的值为false时,注入不生效,不为fasle注入生效
   * value有多个值时,只要有一个值对应为false,则注入不成功      
   */
   String[] value() default {};
   /**
   * 配置文件中key的前缀,可与value 或 name 组合使用 
   */
   String prefix() default "";
   /**
    * 与 value 作用一致
    */
 
String[] name() default {};
     /**
     
     * 与value 或 name 组合使用,只有当value 或 name 对应的值与havingValue的值相同时,注入生效 */ String havingValue() default “”; /** * 配置中缺少对应的属性时,是否可以被注入;为true时缺少对应配置可注入 */ boolean matchIfMissing() default false;}
     
     */
    
String havingValue() default "";
/** *该属性为true时,配置文件中缺少对应的value或name的对应的属性值,也会注入成功 */ boolean matchIfMissing() default false;
     // 对应的测试注入情况
     
     @Configuration
     
     @ConditionalOnProperty(value = “parentName.sonName”)
     
     public class parentNameConfig {
     
     
     }
     
     .yml配置如下:
     
     parentName:
     
     sonName: true     //正常
     
     parentName:
     
     sonName:          //正常,空字符时
     
     parentName:
     
     sonName: false       //失败
     
     parentName:
     
     sonName: null      //正常
     
     parentName:
     
     sonName: 123      //正常
     把第二行换成:
     
     @ConditionalOnProperty(value = “parentName.sonName”,havingValue = “123”)
     
     .yml配置如下:
     
     parentName:
     
     sonName: 123      //正常
     
     parentName:
     
     sonName: 1234      //失败
     
     parentName:
     
     sonName: false      //失败
     把第二行换成:
     
     @ConditionalOnProperty(value = “parentName.sonName”,havingValue = “false”)
     
     .yml配置如下:
     
     parentName:
     
     sonName: false      //正常
     把第二行换成:
     
     @ConditionalOnProperty(prefix = “parentName”,name = “sonName”,havingValue = “123”)
     
     .yml配置如下:
     
     parentName:
     
     sonName: 123      //正常
     
     parentName:
     
     sonName: 1234      //失败,与havingValue给定的值不一致
     把第二行换成:
     
     @ConditionalOnProperty(prefix = “parentName”,name = “sonName”,havingValue = “123”,matchIfMissing = true)
     
     .yml配置如下:
     
     不配置相关参数       //正常,当matchIfMissing = true时,即使没有该parentName.sonName属性也会加载正常
     把第二行换成:
     
     @ConditionalOnProperty(prefix = “parentName”,name = “sonName”,havingValue = “123”,matchIfMissing = false) //这里matchIfMissing默认为false,写不写都行
     
     .yml配置如下:
     
     不配置相关参数       //失败,当matchIfMissing = false时,必须要有对应的property
     
     parentName:
     
     sonName: 123     //正常
     把第二行换成:
     
     @ConditionalOnProperty(prefix = “parentName.”, name = “sonName”)//prefix带了.(点)
     
     .yml配置如下:
     
     parentName:
     
     sonName: true    //正常
     
     parentName:
     
     sonName: 123     //正常
     把第二行换成:
     
     @ConditionalOnProperty(prefix = “parentName”,value = {“sonName2”},name = {“sonName”})
     
     .yml配置如下:
     
     parentName:
     
     sonName: true    //项目Debug启动失败,The name and value attributes of @ConditionalOnProperty are exclusive
     
     //@ConditionalOnProperty的name和value属性是互斥的,不能同时出现
     把第二行换成:
     
     @ConditionalOnProperty(prefix = “parentName”,name = {“sonName”})
     
     .yml配置如下:
     
     parentName:
     
     sonName: true    //正常
     把第二行换成:
     
     @ConditionalOnProperty(prefix = “parentName”,name = {“sonName”,”flag”})  //name中的属性需要两个都存在且都不为false才会加载正常
     
     .yml配置如下:
     
     parentName:
     
     sonName: true
     
     flag: true       //正常
     
     parentName:
     
     sonName: true
     
     flag: 123        //正常
     
     parentName:
     
     sonName: true
     
     flag: false      //失败
     
     parentName:
     
     sonName: false
     
     flag: false      //失败
     把第二行换成:
     
     @ConditionalOnProperty(prefix = “parentName”, name = {“sonName”, “flag”}, havingValue = “false”)
     
     parentName:
     
     sonName: false
     
     flag: false      //正常
     把第二行换成:
     
     @ConditionalOnProperty(prefix = “parentName”, name = {“sonName”, “flag”}, havingValue = “123”)//parentName.sonName和parentName.flag的值都要与havingValue的一致才行
     
     parentName:
     
     sonName: 123
     
     flag: 1234       //失败
     
     parentName:
     
     sonName: 123
     
     flag: 123         //正常
     
     parentName:
     
     sonName: 123     //失败,缺少parentName.flag
     把第二行换成:
     
     @ConditionalOnProperty(prefix = “parentName”, name = {“sonName”, “flag”}, havingValue = “123”,matchIfMissing = true)//matchIfMissing = true允许缺少
     
     parentName:
     
     sonName: 123     //正常
     
     .yml配置如下:
     
     不配置相关参数      //正常
     把第二行换成:
     
     @ConditionalOnProperty(prefix = “parentName”, name = {“sonName”, “flag”}, havingValue = “123”)
     
     .yml配置如下:
     
     不配置相关参数      //失败
    
转载于:https://my.oschina.net/xiaominmin/blog/3034495
 

