<em>Mac</em>Book项目 2009年学校开始实施<em>Mac</em>Book项目,所有师生配备一本<em>Mac</em>Book,并同步更新了校园无线网络。学校每周进行电脑技术更新,每月发送技术支持资料,极大改变了教学及学习方式。因此2011
2021-06-01 09:32:01
父 依 賴 textcolor{orange}{父依賴} 父依賴
spring-boot-dependencies:核心依賴都在父工程中
這裡ctrl+左鍵,點選之後我們可以看到父依賴
這個裡面主要是管理專案的資源過濾及外掛,我們發現他還有一個父依賴
看看下面這個,熟悉嗎?
再點進去,我們發現有很多的依賴。這就是SpringBoot的版本控制中心。
這個地方才是真正管理SpringBoot應用裡面所有依賴的地方,也就是版本控制中心。
我們在寫或引入一些SpringBoot依賴的時候,不需要指定版本,就是因為有這些版本倉庫。
<dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-web</artifactId> </dependency>
啟動器就是springboot的啟動場景 textcolor{red}{啟動器就是SpringBoot的啟動場景} 啟動器就是SpringBoot的啟動場景
springboot-boot-starter-xxx:就是spring-boot的場景啟動器
spring-boot-starter-web:幫我們匯入了web模組正常執行所依賴的元件;也就是自動匯入web環境所有的依賴
SpringBoot將所有的功能場景都抽取出來,做成一個個的starter (啟動器);
要用什麼功能就匯入什麼樣的場景啟動器:只需要在專案中引入這些starter
即可,所有相關的依賴都會匯入進來 ;
我們未來也可以自己自定義 starter;
//程式的主入口 //@SpringBootApplication:標註這個類是一個springBoot的應用 @SpringBootApplication public class HelloSpringBootApplication { public static void main(String[] args) { //將springBoot應用啟動 SpringApplication.run(HelloSpringBootApplication.class, args); } }
看著如此的簡單,它就是通過反射載入這個類的物件,這是表面意思,我們看不到它為啥啟動。
首先我們來看
@SpringBootApplication
我們點選@SpringBootApplication
後可以看到有這麼幾個註解
結論:springBoot所有的自動設定都是在啟動的時候掃描並載入:spring.factories
所有的自動設定類都在這裡面,但是不一定生效,要判斷條件是否成立,只要匯入了對應的start,就有了對應的啟動器,有了啟動器,自動裝配就是生效,之後設定成功
@ComponentScan
這個註解在Spring中非常重要,對應的是XML設定中的元素。
作用:自動掃描並載入符合條件的元件或者bean,將這個bean定義載入到IOC容器中
@ComponentScan(excludeFilters = { @Filter(type = FilterType.CUSTOM, classes = TypeExcludeFilter.class), @Filter(type = FilterType.CUSTOM, classes = AutoConfigurationExcludeFilter.class) })
@SpringBootConfiguration
作用:SpringBoot的設定類 ,標註在某個類上 , 表示這是一個SpringBoot的設定類;
@Target({ElementType.TYPE}) @Retention(RetentionPolicy.RUNTIME) @Documented @Configuration @Indexed public @interface SpringBootConfiguration { @AliasFor( annotation = Configuration.class ) boolean proxyBeanMethods() default true; }
這裡的@Configuration
說明這是一個設定類,這個設定類就是對應Spring的xml組態檔
@Component
說明,啟動類本身也是Spring中的一個元件,負責啟動應用。
@EnableAutoConfiguration
作用:開啟自動設定功能
點進去後會看到
@Target(ElementType.TYPE) @Retention(RetentionPolicy.RUNTIME) @Documented @Inherited @AutoConfigurationPackage @Import(AutoConfigurationImportSelector.class)
然後我們發現了@AutoConfigurationPackage
它的作用是自動設定包
@Import(AutoConfigurationPackages.Registrar.class) public @interface AutoConfigurationPackage { }
@import
:Spring底層註解@import , 給容器中匯入一個元件
AutoConfigurationPackages.Registrar.class
作用:將主啟動類的所在包及包下面所有子包裡面的所有元件掃描到Spring容器 ;
我們退回上一步看一下這個註解
@Import({AutoConfigurationImportSelector.class})
:給容器匯入元件 ;
AutoConfigurationImportSelector :自動設定匯入選擇器,在這個類中有這麼一個方法
/** * Return the auto-configuration class names that should be considered. By default * this method will load candidates using {@link SpringFactoriesLoader} with * {@link #getSpringFactoriesLoaderFactoryClass()}. * @param metadata the source metadata * @param attributes the {@link #getAttributes(AnnotationMetadata) annotation * attributes} * @return a list of candidate configurations */ //獲得候選的設定 protected List<String> getCandidateConfigurations(AnnotationMetadata metadata, AnnotationAttributes attributes) { //這裡的getSpringFactoriesLoaderFactoryClass() //返回的是我們最開是看到啟動自動匯入組態檔的註解類;EnableAutoConfiguration 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; }
在上面這個方法中呼叫了SpringFactoriesLoader
這個類中的靜態方法,我們檢視一下這個類中的loadFactoryNames
這個方法。
public static List<String> loadFactoryNames(Class<?> factoryType, @Nullable ClassLoader classLoader) { ClassLoader classLoaderToUse = classLoader; if (classLoader == null) { classLoaderToUse = SpringFactoriesLoader.class.getClassLoader(); } String factoryTypeName = factoryType.getName(); return (List)loadSpringFactories(classLoaderToUse).getOrDefault(factoryTypeName, Collections.emptyList()); }
發現他又呼叫了loadSpringFactories
這個方法,我們繼續看
private static Map<String, List<String>> loadSpringFactories(ClassLoader classLoader) { Map<String, List<String>> result = (Map)cache.get(classLoader); if (result != null) { return result; } else { HashMap result = new HashMap(); try { Enumeration urls = classLoader.getResources("META-INF/spring.factories"); while(urls.hasMoreElements()) { URL url = (URL)urls.nextElement(); UrlResource resource = new UrlResource(url); Properties properties = PropertiesLoaderUtils.loadProperties(resource); Iterator var6 = properties.entrySet().iterator(); while(var6.hasNext()) { Entry<?, ?> entry = (Entry)var6.next(); String factoryTypeName = ((String)entry.getKey()).trim(); String[] factoryImplementationNames = StringUtils.commaDelimitedListToStringArray((String)entry.getValue()); String[] var10 = factoryImplementationNames; int var11 = factoryImplementationNames.length; for(int var12 = 0; var12 < var11; ++var12) { String factoryImplementationName = var10[var12]; ((List)result.computeIfAbsent(factoryTypeName, (key) -> { return new ArrayList(); })).add(factoryImplementationName.trim()); } } } result.replaceAll((factoryType, implementations) -> { return (List)implementations.stream().distinct().collect(Collectors.collectingAndThen(Collectors.toList(), Collections::unmodifiableList)); }); cache.put(classLoader, result); return result; } catch (IOException var14) { throw new IllegalArgumentException("Unable to load factories from location [META-INF/spring.factories]", var14); } } }
這裡我們發現多次出現了一個叫spring.factoriestextcolor{red}{這裡我們發現多次出現了一個叫spring.factories} 這裡我們發現多次出現了一個叫spring.factories
隨便點一個看看JerseyAutoConfiguration
會發現這都是javaConfig設定類,而且都注入了一些Bean。
所以,自動設定真正實現是從classpath中搜尋所有的META-INF/spring.factories組態檔 ,並將其中對應的 org.springframework.boot.autoconfigure. 包下的設定項,通過反射範例化為對應標註了 @Configuration的JavaConfig形式的IOC容器設定類 , 然後將這些都彙總成為一個範例並載入到IOC容器中。
/META-INF/spring.factories
獲取指定的值;springboot
幫忙做了;spring-boot-autoconfigure-2.5.7.jar
這個包下到此這篇關於最新springboot中必須要了解的自動裝配原理的文章就介紹到這了,更多相關springboot自動裝配原理內容請搜尋it145.com以前的文章或繼續瀏覽下面的相關文章希望大家以後多多支援it145.com!
相關文章
<em>Mac</em>Book项目 2009年学校开始实施<em>Mac</em>Book项目,所有师生配备一本<em>Mac</em>Book,并同步更新了校园无线网络。学校每周进行电脑技术更新,每月发送技术支持资料,极大改变了教学及学习方式。因此2011
2021-06-01 09:32:01
综合看Anker超能充系列的性价比很高,并且与不仅和iPhone12/苹果<em>Mac</em>Book很配,而且适合多设备充电需求的日常使用或差旅场景,不管是安卓还是Switch同样也能用得上它,希望这次分享能给准备购入充电器的小伙伴们有所
2021-06-01 09:31:42
除了L4WUDU与吴亦凡已经多次共事,成为了明面上的厂牌成员,吴亦凡还曾带领20XXCLUB全队参加2020年的一场音乐节,这也是20XXCLUB首次全员合照,王嗣尧Turbo、陈彦希Regi、<em>Mac</em> Ova Seas、林渝植等人全部出场。然而让
2021-06-01 09:31:34
目前应用IPFS的机构:1 谷歌<em>浏览器</em>支持IPFS分布式协议 2 万维网 (历史档案博物馆)数据库 3 火狐<em>浏览器</em>支持 IPFS分布式协议 4 EOS 等数字货币数据存储 5 美国国会图书馆,历史资料永久保存在 IPFS 6 加
2021-06-01 09:31:24
开拓者的车机是兼容苹果和<em>安卓</em>,虽然我不怎么用,但确实兼顾了我家人的很多需求:副驾的门板还配有解锁开关,有的时候老婆开车,下车的时候偶尔会忘记解锁,我在副驾驶可以自己开门:第二排设计很好,不仅配置了一个很大的
2021-06-01 09:30:48
不仅是<em>安卓</em>手机,苹果手机的降价力度也是前所未有了,iPhone12也“跳水价”了,发布价是6799元,如今已经跌至5308元,降价幅度超过1400元,最新定价确认了。iPhone12是苹果首款5G手机,同时也是全球首款5nm芯片的智能机,它
2021-06-01 09:30:45