@Conditional:判断@Conditional指定的条件是否成立,如果成立才会给容器中添加组件,配置类里面的内容才会生效



我们发现有很多的自动配置类,但是这些自动配置类都有指定的条件,必须满足这些条件,自动配置才会生效,比如


那我们怎么查看哪些自动配置类生效了呢
可以通过debug模式
1.application.properties配置以下内容

2.启动运行我们就可以查看到哪些自动配置类生效了
Positive matches:代表生效的自动配置类
Negative matches:没有生效的自动配置类


然后通过实例进行测试 1.编写Admin类

/**
* @author:抱着鱼睡觉的喵喵
* @date:2020/12/22
* @description:
*/
public class Admin {
private String name;
private String img; public Admin() {
} public Admin(String name, String img) {
this.name = name;
this.img = img;
} @Override
public String toString() {
return "admin{" +
"name='" + name + '\'' +
", img='" + img + '\'' +
'}';
} public String getName() {
return name;
} public void setName(String name) {
this.name = name;
}
}

2.编写配置类

@Configuration(proxyBeanMethods = true)//proxyBeanMethods = true为默认值
public class MyConfig { // @Bean("admin")
public Admin admin(){
return new Admin("jerry","@the");
}
}

3.主配置文件

@SpringBootApplication
public class SpringBootOnApplication { public static void main(String[] args) {
ConfigurableApplicationContext run=SpringApplication.run(SpringBootOnApplication.class, args); boolean admin = run.containsBean("admin");
System.out.println(admin);
} }

结果:false
说明容器中没有这个组件

-将配置类中的组件导入

@Configuration(proxyBeanMethods = true)//proxyBeanMethods = true为默认值
public class MyConfig { @Bean("admin")
public Admin admin(){
return new Admin("jerry","@the");
}
}

结果:true

那么真正的测试就开始了,使用衍生注解@ConditionOnBean

编写User类

public class User {

    private String username;

    private String password;

    private int age;

    private Admin admin;

    public Admin getAdmin() {
return admin;
} public void setAdmin(Admin admin) {
this.admin = admin;
} public User() {
} public User(String username, String password, int age) {
this.username = username;
this.password = password;
this.age = age;
} public String getUsername() {
return username;
} public void setUsername(String username) {
this.username = username;
} public String getPassword() {
return password;
} public void setPassword(String password) {
this.password = password;
} public int getAge() {
return age;
} public void setAge(int age) {
this.age = age;
} @Override
public String toString() {
return "User{" +
"username='" + username + '\'' +
", password='" + password + '\'' +
", age=" + age +
", admin=" + admin +
'}';
}
}

配置类中增加组件导入,使用@ConditionOnBean注解进行判断
下面的意思是如果容器中不存在admin组件,则也不导入hao组件

@Configuration(proxyBeanMethods = true)
public class MyConfig { @ConditionalOnBean(name = "admin")
@Bean("hao")
public User user(){
User tom = new User("tom", "123", 20);
//hao组件依赖了admin组件
tom.setAdmin(admin());
return tom;
} @Bean("admin")
public Admin admin(){
return new Admin("jerry","@the");
}
}

主配置文件

@SpringBootApplication
public class SpringBootOnApplication { public static void main(String[] args) {
ConfigurableApplicationContext run=SpringApplication.run(SpringBootOnApplication.class, args); boolean user = run.containsBean("hao");
System.out.println(user);
boolean admin = run.containsBean("admin");
System.out.println(admin);
} }

运行结果:
false
true

为什么会这样呢?分析流程可得,把配置类中的admin组件注册放在user组件注册之后,当程序运行时,执行到user()方法时,由于加了@ConditionOnBean注解,所以会进行判断,看容器中是否存在admin组件,由于admin()方法还未执行,所以容器中没有admin组件;所以此时@ConditionOnBean注解返回false,则不再执行user()方法;即user组件不再导入

我们将改变组件的导入顺序

@Configuration(proxyBeanMethods = true)
public class MyConfig { @Bean("admin")
public Admin admin(){
return new Admin("jerry","@the");
} @ConditionalOnBean(name = "admin")
@Bean("hao")
public User user(){
User tom = new User("tom", "123", 20);
//hao组件依赖了admin组件
tom.setAdmin(admin());
return tom;
} }

再次运行
结果:
true
true


将@ConditionalOnBean注解添加到类的上面

@Configuration(proxyBeanMethods = false)
@ConditionalOnMissingBean (name = "admin")
public class MyConfig { @Bean("user")
public User user(){ //hao组件依赖了admin组件
return new User("tom", "123", 20);
} @Bean("admin")
public Admin admin(){
return new Admin("jerry","@the");
}
}

运行结果:
false
false

这就很容易了,由于事先容器中没有admin组件,所以此时ConditionalOnBean返回false,则这个配置类中的内容不在执行

Spring Boot-@Conditional注解以及衍生注解@ConditionalOnBean的更多相关文章

  1. spring boot集成swagger,自定义注解,拦截器,xss过滤,异步调用,guava限流,定时任务案例, 发邮件

    本文介绍spring boot集成swagger,自定义注解,拦截器,xss过滤,异步调用,定时任务案例 集成swagger--对于做前后端分离的项目,后端只需要提供接口访问,swagger提供了接口 ...

  2. Spring Boot 2.0 教程 | @ModelAttribute 注解

    欢迎关注微信公众号: 小哈学Java 文章首发于个人网站: https://www.exception.site/springboot/spring-boot-model-attribute Spri ...

  3. Spring Boot集成JPA的Column注解命名字段无效的问题

    偶然发现,Spring Boot集成jpa编写实体类的时候,默认使用的命名策略是下划线分隔的字段命名. Spring Boot版本:1.5.4.release 数据表: id int, userNam ...

  4. Spring Boot系列——AOP配自定义注解的最佳实践

    AOP(Aspect Oriented Programming),即面向切面编程,是Spring框架的大杀器之一. 首先,我声明下,我不是来系统介绍什么是AOP,更不是照本宣科讲解什么是连接点.切面. ...

  5. 必须知道的Spring Boot中的一些Controller注解

    这篇文章是抄其他人的,原址:https://cloud.tencent.com/developer/article/1082720 本文旨在向你介绍在Spring Boot中controller中最基 ...

  6. Spring Boot(四)@EnableXXX注解分析

    在学习使用springboot过程中,我们经常碰到以@Enable开头的注解,其实早在Spring3中就已经出现了类似注解,比如@EnableTransactionManagement.@ Enabl ...

  7. spring boot的ComponentScan和ServletComponentScan注解

    ComponentScan 这个注解可以扫描带@Component的类.众所皆知,@RestController和@Configuration和@Service和@Configuration等都有带C ...

  8. 精尽Spring Boot源码分析 - @ConfigurationProperties 注解的实现

    该系列文章是笔者在学习 Spring Boot 过程中总结下来的,里面涉及到相关源码,可能对读者不太友好,请结合我的源码注释 Spring Boot 源码分析 GitHub 地址 进行阅读 Sprin ...

  9. spring boot 使用拦截器,注解 实现 权限过滤

    http://www.cnblogs.com/zhangXingSheng/p/7744997.html spring boot 使用拦截器 实现 用户登录拦截 http://www.cnblogs. ...

随机推荐

  1. Clickhouse 与 Kafka 的数据同步

    作者: LemonNan 原文地址: https://mp.weixin.qq.com/s/SUUHF9R_FKg-3vq7Q3cwBQ 注: 转载需注明作者及原文地址 介绍 Clickhouse 本 ...

  2. 不带头结点的单链表(基于c语言)

    本篇文章的代码大多使用无头结点的单链表: 相关定义: #include <stdio.h> #include <stdlib.h> #include <assert.h& ...

  3. 74CMS 3.0 SQL注入漏洞后台

    代码审计工具:seay CMS:74CMS3.0 一. 启动环境 1.双击运行桌面phpstudy.exe软件 2.点击启动按钮,启动服务器环境 二.代码审计 1.双击启动桌面Seay源代码审计系统软 ...

  4. 利用MSSQL getshell

    此次复现使用的sql server 2000 和sql server 2008两个环境进行的 是在已知数据库密码的基础上进行的 0x01 MSSQL连接 连接MSSQL 2000 新建连接: 填写目的 ...

  5. 麒麟系统开发笔记(二):国产麒麟系统搭建Qt开发环境安装Qt5.12

    前言   开发国产应用,使用到银河麒麟V4,V10,本篇以V10记录,参照上一篇可安装V4.V7.V10三个版本,麒麟V4系自带了Qt,麒麟V10没有自带Qt,需要自己编译搭建环境.   银河麒麟V1 ...

  6. Mysql之锁(一)

    读锁与写锁 读锁:共享锁.Shared Locks.S锁. 写锁:排他锁.Exclusive Locks.X锁. 读锁:只能读不允许写 写锁:不能读也不能写,只允许自己写 但是允许其他事务进行普通的s ...

  7. hashCode()方法的作用?

    hashCode()方法与equals()方法相似,都是来自java.lang.Object类的方法,都允许用户定义的子类重写这两个方法. 一般来说,equals这个方法是给用户调用的,如果你想根据自 ...

  8. SSL的作用?

    SSL能使用户/服务器应用之间的通信不被攻击者窃听,并且始终对服务器进行认证,还可选择对用户进行认证.SSL协议要求建立在可靠的传输层协议(TCP)之上.SSL协议的优势在于它是与应用层协议独立无关的 ...

  9. DateUtils互转工具类

    public class DateUtils { /** * 取系统默认时区ID */ private static final ZoneId ZONE_ID; static { ZONE_ID = ...

  10. python模块相互依赖的解决方案

    第一种:将相互依赖的文件中的其中一个文件的代码移植到另一个文件中... 第二种:将 import .... 或 from ... import 语句的位置移动到def函数内部,由于import和fro ...