时间:2021-05-20
1、conditional注解介绍
含义: 基于条件的注解
作用: 根据是否满足某一个特定条件来决定是否创建某个特定的bean
意义: Springboot实现自动配置的关键基础能力
2、常见conditional注解
@ConditionalOnBean 框架中存在某个Bean时生效
@ConditionalOnMissingBean 在Bean不存在时生效
@ConditionalOnClass框架中存在某个Class时生效
@ConditionalOnMissingClass在Class不存在时生效
@ConditionalOnWebApplication 当前是web环境
@ConditionalOnNotWebApplication 当前不是web环境
@ConditionalOnProperty 当前框架中是否包含特定的属性
@ConditionalOnJava 当前是否存在某个Java版本
3、Conditional的使用
1) 创建A.java,增加注解ConditionalOnProperty,表示系统中有这个属性才实例化A
@Component@ConditionalOnProperty("com.example.condition")public class A {}2) 创建测试类
@RunWith(SpringRunner.class)@SpringBootTest@Import(MyBeanImport.class)public class ConditionTest implements ApplicationContextAware { private ApplicationContext applicationContext; @Test public void testA() { System.out.println(applicationContext.getBean(A.class)); } @Override public void setApplicationContext(ApplicationContext applicationContext) throws BeansException { this.applicationContext = applicationContext; }}3、运行测试类
抛出异常,表示没有找到A这个类。
然后在application.properties文件中增加属性
再次运行测试。成功。
4、A类中有个注解ConditionOnProperty
1) 进入注解ConditionOnProperty。里面有一个@Conditional注解
2) 进入@Conditional注解。里面的value是Class类型,并且继承自Condition接口
3) 进入Condition接口。里面只有一个方法。当这个方法返回true时,这个bean才会注入到容器当中。
5、自定义Conditional 注解
1) 创建MyCondition类。实现Condition接口重写matches方法,符合条件返回true
public class MyCondition implements Condition { @Override public boolean matches(ConditionContext context, AnnotatedTypeMetadata metadata) { String[] properties = (String[]) metadata .getAnnotationAttributes("com.example.demo.condi.MyConditionAnnotation") .get("value"); for(String property : properties){ if(StringUtils.isEmpty(context.getEnvironment().getProperty(property))){ return false; } } return true; }}2) 创建注解MyConditionAnnotation ,并且引入Conditional注解,引入MyCondition类
@Target({ElementType.TYPE, ElementType.METHOD})@Retention(RetentionPolicy.RUNTIME)@Documented@Conditional({MyCondition.class})public @interface MyConditionAnnotation { String[] value() default {};}3) 创建类AA使用注解MyConditionAnnotation
@Component@MyConditionAnnotation({"com.example.condition1","com.example.condition2"})public class AA {}4) 测试
a) 此时并没有com.example.condition1和com.example.condition2这两个属性值,所有测试失败
b) 然后增加这两个属性。
测试成功
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
了解过spring-Boot这个技术的,应该知道Spring-Boot的核心配置文件application.properties,当然也可以通过注解自定义配置文
项目升级到springboot2.3之后,参数校验的注解报错,发现spring-boot-starter-web的依赖项已经去除了依赖点开spring-boot
在Spring4后才引入了@Conditional等条件注解,它是SpringBoot中实现自动配置的最大功臣!那么问题来了:如果我们还在使用Spring3.x
本文介绍了springboot的maven配置依赖详解,分享给大家,具体如下:我们通过引用spring-boot-starter-parent,添加spring
简单讲下用法://引依赖tk.mybatismapper-spring-boot-starter2.1.5com.github.pagehelperpagehe