SpringBoot中@ConditionalOnProperty使用详解
我们经常在 SpringBoot 的自动配置中经常看到此注解,那他到底是干什么用的呢,接下来我们看看他的源码。
@Retention(RetentionPolicy.RUNTIME)
@Target({ElementType.TYPE, ElementType.METHOD})
@Documented
@Conditional({OnPropertyCondition.class})
public @interface ConditionalOnProperty {
// 数组,获取对应property名称的值,与name不可同时使用
String[] value() default {};
// 配置属性名称的前缀,比如com.hb.env
String prefix() default "";
// 数组,配置属性完整名称或部分名称; 可与prefix组合使用,组成完整的配置属性名称,与value不可同时使用
String[] name() default {};
// 可与name组合使用,比较获取到的属性值与havingValue给定的值是否相同,相同才加载配置
String havingValue() default "";
// 缺少该配置属性时是否可以加载。如果为true,没有该配置属性时也会正常加载;反之则不会生效
boolean matchIfMissing() default false;
}
通过 @Conditional (OnPropertyCondition.class) 代码,可以看出 @ConditionalOnProperty 属于 @Conditional 的衍生注解。是否生效由属性来判断。
比如配置:
com.hb.env.type=product
首先看 matchIfMissing 属性,默认情况下值为 false。在 matchIfMissing 为 false 时,如果 name 值为空也就是上面那一行配置没有则不生效;如果 name 不为空,则将该值与 havingValue 指定的值进行比较,如果一样则自动配置生效,反之不会生效。
本作品采用《CC 协议》,转载必须注明作者和本文链接