@ConditionalOnClass(Redis.class) :常用在配置类中,当有对应的类引入,那么就让配置类生效。比如:reids,引入redis类,就会生效redis的配置。
@ConditionalOnMissingClass(Log.class):常用在兜底类中,比如日志配置中,如果某个项目中没有特殊的配置,那么就用兜底的配置,否则就用兜底的配置。这就是没有指定的实现,就会有默认的配置实现。
@ConditionalOnBean(MessageListener.class):常用在MQ消息分发中心,一般都是实现消息分发接口。消息中心就会发消息给你,这就是指定类存在,就会实现对应配置。
@ConditionalOnMissingBean(PulsarClient.class):和@ConditionalOnMissingClass作用类似,基本都是一样用。不过@ConditionalOnMissingClass的要求跟宽松,不用转bean就是了。之前都是用在MQ消息分发中心配置,除非项目中有特殊的配置,不然就用这个默认的配置。
@ConditionalOnProperty("${redis.enable:false}"):常用在配置信息中,用来开关某些配置信息。
@ConditionalOnExpression("${redis.enable:false}"):和@ConditionalOnProperty作用差不多,只是比它多了支持springEl表达式。
@ConditionalOnResource(resources = "/logback.xml"):如果我们要加载的 bean 依赖指定资源是否存在于 classpath 中,那么我们就可以使用这个注解。使用该注解的目的是,注解在Configuration bean上,在其加载之前对指定资源进行校验,是否存在,如果不存在,抛出异常;(用的比较少,毕竟很少地方会做这种强校验,这个注解不是很熟悉。讲解不对的地方,大佬指点一下,因为我记得之前测试过,好像也能不做强校验)