写在前面
在开发基于SpringBoot框架的项目时,会用到下面的条件注解,有时会有需要控制配置类是否生效或注入到Spring上下文中的场景,可以使用@ConditionalOnProperty注解来控制@Configuration的注解是否生效。
实现原理
@ConditionalOnProperty通过havingValue与配置文件中的值进行对比,如果对比值返回TRUE则配置类生效,反之失效。 Spring Boot 对 @Conditional 注解为我们做了细化,类似的注解共有14个,这些注解都定义在 org.springframework.boot.autoconfigure.condition包下。
注解说明
A. 这些注解都可以应用在 TYPE 上,也就是说,Spring 自动扫描的一切类 (@Configuration, @Component, @Service, @Repository, @Controller) 都可以通过添加相应的 @ConditionalOnXxxx 来判断是否加载; B. 这些注解都可以应用在 METHOD 上,所以有 @Bean 标记的方法也可以应用这些注解; C. 都使用了 @Conditional 注解来标记,OnBeanCondition 等自定义 Condition 也是实现了 Condition 接口。
源码分析
@Retention(RetentionPolicy.RUNTIME)
@Target({ElementType.TYPE, ElementType.METHOD})
@Documented
@Conditional({OnPropertyCondition.class})
public @interface ConditionalOnProperty {
String[] value() default {};
String[] name() default {};
String prefix() default "";
String havingValue() default "";
boolean matchIfMissing() default false;
}
案例分析
配置信息
servicex.swagger.config.enabled=true
注解示例①
@Configuration
@EnableAutoConfiguration
@ConditionalOnProperty(name = "servicex.swagger.config.enabled", matchIfMissing = true)
public class SwaggerAutoConfiguration {
}
注解示例②
@Configuration
@EnableAutoConfiguration
@ConditionalOnProperty(prefix = "servicex.swagger.config", name = "enabled")
public class SwaggerAutoConfiguration {
}
注解示例③
@Configuration
@EnableAutoConfiguration
@ConditionalOnProperty(name = "servicex.swagger.config.enabled")
public class SwaggerAutoConfiguration {
}
注解示例④
@Configuration
@EnableAutoConfiguration
@ConditionalOnProperty(name = "servicex.swagger.config.enabled", havingValue = "true")
public class SwaggerAutoConfiguration {
}
注解示例⑤
@Configuration
@EnableAutoConfiguration
@ConditionalOnProperty(name = "servicex.swagger.config.enabled", havingValue = "false")
public class SwaggerAutoConfiguration {
}
servicex.swagger.config.enabled | havingValue | 是否会加载 | 描述 |
---|
true | true | √ | 对比值相同则加载 | false | false | √ | 对比值相同则加载 | true | false | × | 对比值不相同则不会加载 | false | true | × | 对比值不相同则不会加载 | true | / | √ | 加载(如果havingValue不设置,是否加载由配置项决定) | false | / | × | 不加载(如果havingValue不设置,是否加载由配置项决定) |
常见注解
ConditionalOnProperty
ConditionalOnResource
ConditionalOnBean
@ConditionalOnBean(MyAutoConfiguration.class)
public class SwaggerAutoConfiguration {
}
ConditionalOnMissingBean
ConditionalOnClass
ConditionalOnMissingClass
ConditionalOnExpression
@ConditionalOnExpression("${servicex.swagger.config.enabled:true} and ${swagger.config.enabled:true}")
public class SwaggerAutoConfiguration {
}
ConditionalOnResource
@ConditionalOnResource(resources = "/banner.txt")
public class SwaggerAutoConfiguration {
}
相关博文
在SpringBoot中如何自定义starter SpringBoot - @ConditionalOnMissingBean注解使用详解 SpringBoot - @ConfigurationProperties注解使用详解
|