SpringBoot中@EnableAutoConfiguration注解源碼分析
工作原理
SpringBoot通過@EnableAutoConfiguration注解開啟自動配置,加載spring.factories文件中注冊的各種AutoConfiguration
當某個AutoConfiguration類滿足@Conditional指定的生效條件時,實例化該AutoConfiguration類中定義的Bean,注入到Spring容器中,就可以完成依賴框架的自動配置。
- 需要和@Configuration配合使用;
- 用于實例化依賴包中的對象;
- 一般需要在META-INF/spring.factories中進行配置;
- 經(jīng)常用于自定義的starter中。
應用場景
@EnableAutoConfiguration,主要是用于加載Starter目錄包之外的、需要Spring自動生成Bean對象的、帶有@Configuration注解的類。
一般用于對各種引入的spring-boot-starter依賴包指定的(spring.factories)類進行實例化。
源碼分析
@EnableAutoConfiguration是被組合到@SpringBootApplication注解中被引入的。
@SpringBootApplication包含三個重要的注解,分別為:
- @SpringBootConfiguration
- @EnableAutoConfiguration
- @ComponentScan
從下面的源碼可以知道,@EnableAutoConfiguration是由@AutoConfigurationPackage 和 @Import({AutoConfigurationImportSelector.class})這兩個注解組成的。
- @SpringBootApplication = @SpringBootConfiguration + @EnableAutoConfiguration + @ComponentScan
- @EnableAutoConfiguration = @AutoConfigurationPackage + @Import({AutoConfigurationImportSelector.class})
@Target({ElementType.TYPE}) @Retention(RetentionPolicy.RUNTIME) @Documented @Inherited @SpringBootConfiguration @EnableAutoConfiguration @ComponentScan( excludeFilters = {@Filter( type = FilterType.CUSTOM, classes = {TypeExcludeFilter.class} ), @Filter( type = FilterType.CUSTOM, classes = {AutoConfigurationExcludeFilter.class} )} ) public @interface SpringBootApplication { @AliasFor( annotation = EnableAutoConfiguration.class ) Class<?>[] exclude() default {}; @AliasFor( annotation = EnableAutoConfiguration.class ) String[] excludeName() default {}; @AliasFor( annotation = ComponentScan.class, attribute = "basePackages" ) String[] scanBasePackages() default {}; @AliasFor( annotation = ComponentScan.class, attribute = "basePackageClasses" ) Class<?>[] scanBasePackageClasses() default {}; @AliasFor( annotation = ComponentScan.class, attribute = "nameGenerator" ) Class<? extends BeanNameGenerator> nameGenerator() default BeanNameGenerator.class; @AliasFor( annotation = Configuration.class ) boolean proxyBeanMethods() default true; }
總結(jié)
@EnableAutoConfiguration是一個組合注解,該注解內(nèi)部使用@Import注解,引入了配置類AutoConfigurationImportSelector.Class
該類是ImportSelect接口的實現(xiàn)類,它重寫了接口中的selectImports()方法,得到一個String類型的數(shù)組。
該數(shù)組是通過底層加載配置文件 META-INF/spring.factories得到的,該配置文件中定義了大量的配置類,Sringboot 啟動的時候會加載所有的selector并執(zhí)行selectImports方法,從而完成自動配置。
不是所有的類在初始化時都可以自動加載進SpringIOC容器中,要結(jié)合@Conditional這個條件注解進行判斷,待加載的配置類如果滿足所有的@Conditional注解限定的條件,才會進行自動加載。
到此這篇關(guān)于SpringBoot中@EnableAutoConfiguration注解源碼分析的文章就介紹到這了,更多相關(guān)@EnableAutoConfiguration注解源碼內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
- SpringBoot自動配置@EnableAutoConfiguration過程示例
- SpringBoot中的@EnableAutoConfiguration注解解析
- Springboot注解之@EnableAutoConfiguration詳解
- SpringBoot中@EnableAutoConfiguration和@Configuration的區(qū)別
- SpringBoot使用@EnableAutoConfiguration實現(xiàn)自動配置詳解
- 解析SpringBoot @EnableAutoConfiguration的使用
- SpringBoot中@EnableAutoConfiguration注解的實現(xiàn)
相關(guān)文章
Mybatis如何獲取insert新增數(shù)據(jù)id值
這篇文章主要介紹了Mybatis如何獲取insert新增數(shù)據(jù)id值問題,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教2024-05-05Mybatis配置之<properties>屬性配置元素解析
這篇文章主要介紹了Mybatis配置之<properties>屬性配置元素解析,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2021-07-07java?常規(guī)輪詢長輪詢Long?polling實現(xiàn)示例詳解
這篇文章主要為大家介紹了java?常規(guī)輪詢長輪詢Long?polling實現(xiàn)示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪2022-12-12