大家好,这里是教授.F
目录
@SpringBootApplication:
@EableAutoConfiguration:
上一篇文章粗略的讲了自动配置机制,二说系列将从源码的角度进行讲解。
@SpringBootApplication:
首先我们还是得从@SpringBootApplication开始讲起。在@SpringBootApplication是由@Configuration、@ComponentScan和@EableAutoConfiguration组成的。@ComponentScan完成对被@Conponent注解的bean,默认情况下,扫描该类所在包下的所有类。@Configuration允许上下文注册额外的 bean 或导入其他配置类。 @EableAutoConfiguration则负责启动SpringBoot的自动配置。请看下图。
@EableAutoConfiguration:
下面我们从源码来对 @EableAutoConfiguration进行解剖。
import java.lang.annotation.Documented;
import java.lang.annotation.ElementType;
import java.lang.annotation.Inherited;
import java.lang.annotation.Retention;
import java.lang.annotation.RetentionPolicy;
import java.lang.annotation.Target;
import org.springframework.context.annotation.Import;
@Target({ElementType.TYPE})
@Retention(RetentionPolicy.RUNTIME)
@Documented
@Inherited
@AutoConfigurationPackage
@Import({AutoConfigurationImportSelector.class})
public @interface EnableAutoConfiguration {
String ENABLED_OVERRIDE_PROPERTY =
"spring.boot.enableautoconfiguration";
Class<?>[] exclude() default {};
String[] excludeName() default {};
}
@EableAutoConfiguration启动自动配置本质上就是能控制bean。
看看源码:
@Import({AutoConfigurationImportSelector.class})
@EableAutoConfiguration通过注解@Import导入AutoConfigurationImportSelector.class。( @Import 注解可以导入配置类或者 Bean 到当前类中)。AutoConfigurationImportSelector类中有getCandidateConfigurations。getCandidateConfigurations能将所有自动配置类的信息封装成List返回。这些信息会被Spring当作bean来管理。
protected List<String> getCandidateConfigurations(AnnotationMetadata
metadata, AnnotationAttributes attributes) {
List<String> configurations =
SpringFactoriesLoader.loadFactoryNames(getSpringFactoriesLoaderFactoryClass()
,getBeanClassLoader());
Assert.notEmpty(configurations, "No auto configuration classes found
in META-INF/spring.factories. If you "
+ "are using a custom packaging, make sure that file is
correct.");
return configurations;
}
有了这些,现在只需要@Conditional 注解。 @ConditionalOnClass (指定的类必须存在于类路径 下)。将类存在于指定的地方,这样自动将配置就完成了