亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

Spring Boot Starter 自動裝配原理全解析

 更新時間:2025年04月22日 09:53:38   作者:葵續(xù)淺笑  
Spring Boot Starter 的核心設計理念是 約定優(yōu)于配置,其核心實現(xiàn)基于 自動配置(Auto-Configuration) 和 條件化注冊(Conditional Registration),這篇文章主要介紹了Spring Boot Starter 自動裝配原理全解析,需要的朋友可以參考下

Spring Boot Starter 的核心設計理念是 約定優(yōu)于配置,其核心實現(xiàn)基于 自動配置(Auto-Configuration)條件化注冊(Conditional Registration)。以下是其生效原理:

約定大于配置

通過預定義合理的默認行為和規(guī)范,減少開發(fā)者需要手動配置的步驟。比較顯著的變化就是減少XML配置。還有一些實際體現(xiàn)如下所示:

  • 項目結(jié)構(gòu)約定
    • 默認目錄結(jié)構(gòu):如 src/main/java 存放代碼,src/main/resources 存放配置文件。
    • 配置文件命名application.propertiesapplication.yml 自動被加載,無需顯式指定路徑。
  • 自動配置(Auto-Configuration)
    • 條件化 Bean 注冊:根據(jù)類路徑依賴(如存在 DataSource 類)自動配置數(shù)據(jù)庫連接池。
    • 默認參數(shù)值:如嵌入式 Tomcat 默認端口為 8080,無需手動指定。
  • Starter 依賴
    • 依賴聚合:引入 spring-boot-starter-web 即自動包含 Web 開發(fā)所需的所有依賴(如 Tomcat、Jackson、Spring MVC)。
    • 開箱即用:無需手動管理版本兼容性。
  • RESTful 路由映射
    • 注解驅(qū)動:通過 @GetMapping("/path") 即可定義接口,無需在 XML 中配置路由規(guī)則。

自動配置機制

觸發(fā)階段:@EnableAutoConfiguration

  • 應用啟動時,@SpringBootApplication 組合了 @EnableAutoConfiguration,觸發(fā)自動配置流程。
  • AutoConfigurationImportSelector 被調(diào)用,負責加載所有候選的自動配置類。
public String[] selectImports(AnnotationMetadata metadata) {
  // 1. 加載所有候選自動配置類
  List<String> configurations = getCandidateConfigurations();
  // 2. 去重、過濾、排序
  configurations = removeDuplicates(configurations);
  configurations = filter(configurations, autoConfigurationMetadata);
  return configurations.toArray(new String[0]);
}

加載與篩選:spring.factories

  • 加載所有候選配置類

從所有 META-INF/spring.factories 文件中讀取 EnableAutoConfiguration 對應的配置類。在 Spring Boot 3.x 中,自動配置類的加載方式從 spring.factories 過渡到 AutoConfiguration.imports,并引入了 ImportCandidates 類來處理這一變化。

  • 去重與過濾

移除重復的配置類,并通過條件注解(如 @ConditionalOnClass ,@ConditionalOnMissingBean ) 有選擇的保留當前環(huán)境的配置類。

  • @ConditionalOnClass:類路徑存在指定類時生效
  • @ConditionalOnMissingBean:容器中不存在指定 Bean 時生效
  • @ConditionalOnProperty:配置屬性匹配時生效

排序

根據(jù) @AutoConfigureOrder@AutoConfigureAfter 調(diào)整配置類的加載順序。

Bean 注冊

  • 篩選后的自動配置類被解析為標準的 @Configuration 類。
  • 每個配置類中的 @Bean 方法根據(jù)條件注解動態(tài)注冊 Bean 到 Spring 容器。

編寫自定義Spring Boot Starter

項目結(jié)構(gòu)規(guī)劃

建議分為兩個模塊:

  • 自動配置模塊:包含核心邏輯和自動配置類(如 hello-spring-boot-autoconfigure)。
  • Starter模塊:空項目,僅作為依賴聚合(如 hello-spring-boot-starter)。
hello-spring-boot-starter-parent(父POM)
├── hello-spring-boot-autoconfigure(自動配置模塊)
└── hello-spring-boot-starter(Starter模塊)
hello-spring-boot-starter/
├── hello-spring-boot-autoconfigure/
│   ├── src/
│   │   ├── main/
│   │   │   ├── java/com/example/autoconfigure/
│   │   │   │   ├── HelloAutoConfiguration.java
│   │   │   │   ├── HelloProperties.java
│   │   │   │   └── HelloService.java
│   │   │   └── resources/
│   │   │       └── META-INF/
│   │   │           └── spring.factories
│   │   └── test/
│   └── pom.xml
├── hello-spring-boot-starter/
│   └── pom.xml
└── pom.xml

創(chuàng)建自動配置模塊(hello-spring-boot-autoconfigure)

添加Maven依賴

<!-- pom.xml -->
<dependencies>
    <!-- Spring Boot 自動配置基礎依賴 -->
    <dependency>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-autoconfigure</artifactId>
        <version>3.1.5</version>
    </dependency>
    <!-- 可選:配置屬性處理 -->
    <dependency>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-configuration-processor</artifactId>
        <version>3.1.5</version>
        <optional>true</optional>
    </dependency>
</dependencies>

定義核心服務類

public class HelloService {
    private String message = "Hello, World!";  // 默認消息
    public String sayHello() {
        return message;
    }
    // Getter和Setter用于通過配置修改message
    public String getMessage() { return message; }
    public void setMessage(String message) { this.message = message; }
}

定義配置屬性類(可選)

@ConfigurationProperties(prefix = "hello")
public class HelloProperties {
    private String message = "Hello, World!";
    // Getter和Setter
    public String getMessage() { return message; }
    public void setMessage(String message) { this.message = message; }
}

編寫自動配置類

@Configuration
@EnableConfigurationProperties(HelloProperties.class)  // 啟用配置屬性
@ConditionalOnClass(HelloService.class)  // 當HelloService在類路徑時生效
public class HelloAutoConfiguration {
    @Bean
    @ConditionalOnMissingBean  // 當用戶未自定義HelloService時生效
    public HelloService helloService(HelloProperties properties) {
        HelloService service = new HelloService();
        service.setMessage(properties.getMessage());
        return service;
    }
}

注冊自動配置

resources/META-INF/ 下創(chuàng)建 spring.factories 文件:

org.springframework.boot.autoconfigure.EnableAutoConfiguration=\
com.example.autoconfigure.HelloAutoConfiguration

創(chuàng)建Starter模塊(hello-spring-boot-starter)

添加Maven依賴

<!-- pom.xml -->
<dependencies>
    <!-- 引入自動配置模塊 -->
    <dependency>
        <groupId>com.example</groupId>
        <artifactId>hello-spring-boot-autoconfigure</artifactId>
        <version>1.0.0</version>
    </dependency>
</dependencies>

使用自定義Starter

在應用中引入Starter依賴

<!-- 用戶項目的pom.xml -->
<dependency>
    <groupId>com.example</groupId>
    <artifactId>hello-spring-boot-starter</artifactId>
    <version>1.0.0</version>
</dependency>

在代碼中注入Bean

@RestController
public class HelloController {
    @Autowired
    private HelloService helloService;
    @GetMapping("/hello")
    public String hello() {
        return helloService.sayHello();
    }
}

自定義配置(可選)

application.properties 中修改消息:

hello.message=你好, Spring Boot!

到此這篇關(guān)于Spring Boot Starter 自動裝配原理的文章就介紹到這了,更多相關(guān)Spring Boot Starter 自動裝配內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • FeignClient如何共享Header及踩坑過程記錄

    FeignClient如何共享Header及踩坑過程記錄

    這篇文章主要介紹了FeignClient如何共享Header及踩坑過程記錄,
    2022-03-03
  • springboot的maven多模塊混淆jar包的實現(xiàn)方法

    springboot的maven多模塊混淆jar包的實現(xiàn)方法

    springboot可以使用proguard-maven-plugin 這個插件 在 pom.xml 中自定義proguard 的指令,本文基于 springboot + maven + proguard 的maven多模塊架構(gòu)進行代碼混淆,需要的朋友可以參考下
    2024-03-03
  • jdk中動態(tài)代理異常處理分析:UndeclaredThrowableException

    jdk中動態(tài)代理異常處理分析:UndeclaredThrowableException

    最近在工作中遇到了報UndeclaredThrowableException的錯誤,通過查找相關(guān)的資料,終于解決了,所以這篇文章主要給大家介紹了關(guān)于jdk中動態(tài)代理異常處理分析:UndeclaredThrowableException的相關(guān)資料,需要的朋友可以參考下
    2018-04-04
  • IDEA插件推薦之Maven-Helper的教程圖解

    IDEA插件推薦之Maven-Helper的教程圖解

    這篇文章主要介紹了IDEA插件推薦之Maven-Helper的相關(guān)知識,本文通過圖文并茂的形式給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考
    2020-07-07
  • Spring?boot?admin?服務監(jiān)控利器詳解

    Spring?boot?admin?服務監(jiān)控利器詳解

    這篇文章主要介紹了Spring?boot?admin?服務監(jiān)控利器詳解,文章圍繞主題展開詳細的內(nèi)容介紹,具有一定的參考價值,需要的小伙伴可以參考一下
    2022-08-08
  • Java數(shù)據(jù)結(jié)構(gòu)實現(xiàn)二維數(shù)組與稀疏數(shù)組轉(zhuǎn)換詳解

    Java數(shù)據(jù)結(jié)構(gòu)實現(xiàn)二維數(shù)組與稀疏數(shù)組轉(zhuǎn)換詳解

    稀疏數(shù)組是用于優(yōu)化,壓縮具有以下特點的二維數(shù)組:當二維數(shù)組中的元素大部分相同,有意義的數(shù)據(jù)元素較少時,可以使用稀疏數(shù)組進行簡化,節(jié)省存儲空間
    2021-10-10
  • Java19新特性虛擬線程的具體使用

    Java19新特性虛擬線程的具體使用

    Java 19 引入了虛擬線程,這是 JDK Project Loom 項目中的重要新特性,目的是簡化 Java 中的并發(fā)編程,并提高線程管理的效率和性能,下面就來具體介紹下
    2024-09-09
  • Spring Boot 中的 @ConditionalOnBean 注解作用及基本用法

    Spring Boot 中的 @ConditionalOnBean 注解作用及基

    在 Spring Boot 中,@ConditionalOnBean 可以幫助我們根據(jù) 是否存在特定 Bean 來 動態(tài)注冊 Bean,廣泛用于 按需加載、自動配置 等場景,本文給大家介紹Spring Boot 中的 @ConditionalOnBean 注解,感興趣的朋友一起看看吧
    2025-04-04
  • 深入理解Java設計模式之命令模式

    深入理解Java設計模式之命令模式

    這篇文章主要介紹了JAVA設計模式之命令模式的的相關(guān)資料,文中示例代碼非常詳細,供大家參考和學習,感興趣的朋友可以了解
    2021-11-11
  • Java8?Stream教程之collect()的技巧

    Java8?Stream教程之collect()的技巧

    Java8引入了全新的Stream?API,這里的Stream和I/O流不同,它更像具有Iterable的集合類,但行為和集合類又有所不同,下面這篇文章主要給大家介紹了關(guān)于Java8?Stream教程之collect()的技巧,需要的朋友可以參考下
    2022-09-09

最新評論