【SpringBoot】@ConditionalOnProperty 条件注解

@ConditionalOnProperty是SpringBoot中用于条件装配的一个注解,它允许根据配置属性的值来决定是否加载某个类或方法。注解包含name、prefix、havingValue等属性,通过这些属性可以灵活控制组件的启用和禁用。例如,当配置属性is_load_bean为true时,才会加载相应的Bean。此外,文章还提到了其他类似的条件注解,如@ConditionalOnClass和@ConditionalOnMissingBean。

SpringBoot @ConditionalOnProperty 注解

简介

@ConditionalOnProperty:根据属性值来控制类或某个方法是否需要加载。它既可以放在类上也可以放在方法上

@ConditionalOnProperty属性

@Retention(RetentionPolicy.RUNTIME)
@Target({ ElementType.TYPE, ElementType.METHOD })
@Documented
@Conditional(OnPropertyCondition.class)
public @interface ConditionalOnProperty {

	/**
	 * name别名,数组类型,获取对应property名称的值,与name不能同时使用
	 */
	String[] value() default {};

	/**
	 * 属性前缀,未指定时,自动以点"."结束,有效前缀由一个或多个词用点"."连接。比如spring.http.encoding
     * 如:spring.datasource
	 */
	String prefix() default "";

	/**
	 * 属性名称,配置属性完整名称或部分名称,可与prefix组合使用,不能与value同时使用
	 */
	String[] name() default {};

	/**
	 * 可与name组合使用,比较获取到的属性值与havingValue的值是否相同,相同才加载配置
	 */
	String havingValue() default "";

	/**
	 * 缺少该配置属性时是否加载,默认为false。如果为true,没有该配置属性时也会正常加载;反之则不会生效
	 */
	boolean matchIfMissing() default false;
}

使用方法

@ConditionalOnProperty的核心功能是通过属性name以及havingValue来实现的。

matchIfMissing 属性

如果配置文件中未进行对应属性配置时的默认处理:默认情况下matchIfMissing为false,也就是说如果未进行属性配置,则自动配置不生效。
如果matchIfMissing为true,则表示如果没有对应的属性配置,则自动配置默认生效。

name 属性

从配置文件 application.properties / application.yml中读取某个属性值.

注意:matchIfMissing为false时, name 如果为空,则返回false,如果name 不为空,那就会去与havingValue判断。如果一样则返回true,反之返回false,返回false 的话,就不会去加载了哦

havingValue

匹配属性里的值

非常简单的示例

配置文件

# 是否加载
is_load_bean: true
@Slf4j
@Configuration
public class LoadConditionalProperty {

    @Value("${is_load_bean}")
    private String isLoadBean;

    @Bean
    @ConditionalOnProperty(value = "is_load_bean",havingValue = "true",matchIfMissing = true)
    public void loadBean(){
        log.info("是否加载当前类");
    }

    @Bean
    public void compareLoadBean(){
        log.info("加载bean属性:" + isLoadBean);
    }
}

我们可以通过修改配置文件中is_load_bean的值,观察BEAN是否加载。

补充个例子

假如我们需要把User加载到 容器里面。

public class User {
}
@Slf4j
@Configuration
public class UserConfig {

    @Bean
    @ConditionalOnProperty(value = "is_load_bean",havingValue = "true",matchIfMissing = true)
    public User user(){
        return new User();
    }
}

最后的最后

像此类的注解还是有很多,比如:

注解名称说明
@ConditionalOnClass当Spring加载的Bean被@ConditionOnClass注解标记时,类加载器会先去先找到指定的Class, 如果没有找到目标Class,那么被ConditionOnClass注解标记的类不会被Spring装载
@ConditionalOnMissingClass跟上面相反,ConditionalOnMissingBean是指如果没有找到目标Class, 那么就装载该类
@ConditionalOnBean当Spring加载的Bean被@ConditionalOnBean注解标记时,接下来会先找到指定的Bean,如果没有找到目标Bean,那么被@ConditionalOnBean标记的类不会被Spring装载
@ConditionalOnMissingBean跟上面相反,ConditionalOnMissingBean是指如果没有Class, 那么就装载该Bean。
@ConditionalOnProperty注解Spring Boot中的一个条件注解,用于根据指定的属性值来决定是否加载或创建一个bean。该注解的作用是根据配置文件中的属性值来动态控制bean的创建过程。 要验证@ConditionalOnProperty注解,您可以按照以下步骤进行操作: 1. 确保您已经添加了Spring Boot的依赖,以便可以使用该注解。 2. 在您的Spring Boot应用程序中选择一个合适的类(通常是配置类或启动类),并在该类上添加@ConditionalOnProperty注解。 3. 在@ConditionalOnProperty注解中,您需要指定一个或多个属性的名称和期望的值。例如,假设您想要根据"myapp.feature.enabled"属性的值来决定是否加载一个bean: ```java @Configuration @ConditionalOnProperty(name = "myapp.feature.enabled", havingValue = "true") public class MyFeatureConfig { // Bean definitions and other configurations } ``` 4. 在配置文件(通常是application.properties或application.yml)中添加相应的属性及其值。例如,在application.properties文件中添加以下内容: ``` myapp.feature.enabled=true ``` 这将启用"MyFeatureConfig"类中的bean加载。 5. 运行您的Spring Boot应用程序,并确保启动过程中没有错误或警告。 如果配置文件中指定的属性值与@ConditionalOnProperty注解中指定的期望值匹配,那么该注解所标注的类或bean将会被加载或创建。如果不匹配,则该类或bean将被跳过。 请注意,@ConditionalOnProperty注解还有其他可用的属性,可以用于更复杂的条件匹配逻辑。您可以参考Spring Boot官方文档以获取更多详细信息和示例。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值