案例代碼:https://gitee.com/flymini/codes01/tree/master/springboot_/starter_
****
**1. 為什么要自定義場景啟動器**
* 可能官方提供的場景啟動器不滿足你的要求。
* 可能是你想開發一個被 SpringBoot 兼容的框架。比如 Mybatis 想要被 SpringBoot 兼容,則 Mybatis 團隊自己開發了一個 mybatis 的場景啟動器。
```xml
<dependency>
<groupId>org.mybatis.spring.boot</groupId>
<artifactId>mybatis-spring-boot-starter</artifactId>
<version>1.3.2</version>
</dependency>
```
* 可能你想要在項目啟動時自動加載一下依賴組件。
**2. 自定義場景啟動器需考慮如下因素**
* 場景啟動器需要引入哪些依賴。
* 自動配置類需要用到哪些注解。
[TOC]
# 1. WebMvcAutoConfiguration源碼
1. 通過看 WebMvcAutoConfiguration 來了解一下編寫一個場景啟動器可能需要用到哪些注解。
```java
package org.springframework.boot.autoconfigure.web.servlet;
// 指定類為配置類
@Configuration(
proxyBeanMethods = false
)
// 當應用是Web應用時讓該配置類生效
@ConditionalOnWebApplication(
type = Type.SERVLET
)
// 當存在Servlet、DispatcherServlet,WebMvcConfigurer時才讓配置類生效
@ConditionalOnClass({Servlet.class, DispatcherServlet.class, WebMvcConfigurer.class})
// 當不存在WebMvcConfigurationSupport才讓這個配置類生效
@ConditionalOnMissingBean({WebMvcConfigurationSupport.class})
// 指定該配置類生效的順序,當大于0時,數字越小越先被執行
@AutoConfigureOrder(-2147483638)
// 指定在這三個類被執行后才能執行該配置類
@AutoConfigureAfter({DispatcherServletAutoConfiguration.class, TaskExecutionAutoConfiguration.class, ValidationAutoConfiguration.class})
public class WebMvcAutoConfiguration {
@Bean // 將方法的返回值注入到IoC容器中,<bean class="方法返回值"/>,方法名作為<bean id="方法名"/>
@ConditionalOnMissingBean({HiddenHttpMethodFilter.class})
@ConditionalOnProperty(
prefix = "spring.mvc.hiddenmethod.filter",
name = {"enabled"},
matchIfMissing = false
)
public OrderedHiddenHttpMethodFilter hiddenHttpMethodFilter() {
return new OrderedHiddenHttpMethodFilter();
}
@Configuration(
proxyBeanMethods = false
)
@Import({WebMvcAutoConfiguration.EnableWebMvcConfiguration.class})
// 結合對應的XXXProperties來綁定相關的配置,這些配置就是在application.properties中可以配置的屬性
// EnableConfigurationProperties讓XXXProperties這些配置生效
@EnableConfigurationProperties({WebMvcProperties.class, ResourceProperties.class})
@Order(0)
public static class WebMvcAutoConfigurationAdapter implements WebMvcConfigurer {
...
}
```
2. 需要將該類配置在 META-INF/spring.factories 文件中才能使它生效。

```xml
# Auto Configure
org.springframework.boot.autoconfigure.EnableAutoConfiguration=\
org.springframework.boot.autoconfigure.web.servlet.WebMvcAutoConfiguration,\
```
<br/>
# 2. 自定義場景啟動器
## 2.1 創建自動配置類模塊
**1. 創建模塊:learn-custom-autoconfig**
```xml
<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
<modelVersion>4.0.0</modelVersion>
<parent>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-parent</artifactId>
<version>2.3.12.RELEASE</version>
<relativePath/> <!-- lookup parent from repository -->
</parent>
<groupId>com.learn.example</groupId>
<artifactId>learn-custom-autoconfig</artifactId>
<version>1.0-SNAPSHOT</version>
<properties>
<maven.compiler.source>8</maven.compiler.source>
<maven.compiler.target>8</maven.compiler.target>
</properties>
<dependencies>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
</dependency>
<dependency>
<groupId>org.projectlombok</groupId>
<artifactId>lombok</artifactId>
<version>1.18.24</version>
</dependency>
</dependencies>
</project>
```
**2. 當前模塊的properties類**
```java
@Data
@ConfigurationProperties(prefix = "custom.config.account")
public class AccountProperties {
private String username;
private String password;
}
```
**3. 在當前模塊提供一個獲取properties類的API**
```java
@Data
public class AccountService {
private AccountProperties properties;
}
```
**4. 將AccountService注冊到IoC容器中**
```java
@Configuration //標注該類為配置類
@ConditionalOnWebApplication //當前項目是Web應用時這個配置類生效
@EnableConfigurationProperties(AccountProperties.class) //將屬性類加載到當前配置類中
public class CustomAutoConfiguration {
@Autowired
private AccountProperties properties;
@Bean
public AccountService getAccountService() {
AccountService impl = new AccountService();
impl.setProperties(properties);
return impl;
}
}
```
**5. 將配置類CustomAutoConfiguration添加到`resources/META-INF/spring.factories`**
```factories
org.springframework.boot.autoconfigure.EnableAutoConfiguration=\
learn.custom.autoconfig.config.CustomAutoConfiguration
```
>[info]提醒:不要給當前模塊添加啟動類。
<br/>
## 2.2 創建場景啟動器模塊
**1. 創建啟動器模塊:custom-spring-boot-starter**


```
/*********************啟動器命名規范***************************/
------------ 官方命名空間 ------------
前綴:spring-boot-starter
模式:spring-boot-starter-模塊名
舉例:spring-boot-starter-web、spring-boot-starter-jdbc
------------ 自定義命名空間 ------------
后綴:spring-boot-starter
模式:模塊名-spring-boot-starter
舉例:mybatis-spring-boot-starter
```
**2. 在當前模塊引入自動配置類模塊**
```xml
<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
<modelVersion>4.0.0</modelVersion>
<groupId>com.learn.example</groupId>
<artifactId>custom-spring-boot-starter</artifactId>
<version>1.0-SNAPSHOT</version>
<properties>
<maven.compiler.source>8</maven.compiler.source>
<maven.compiler.target>8</maven.compiler.target>
</properties>
<dependencies>
<dependency>
<groupId>com.learn.example</groupId>
<artifactId>learn-custom-autoconfig</artifactId>
<version>1.0-SNAPSHOT</version>
</dependency>
</dependencies>
</project>
```
<br/>
## 2.3 創建項目來做測試
**1. 創建一個SpringBoot項目來做測試:com-custom-test**
```xml
<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
<modelVersion>4.0.0</modelVersion>
<groupId>com.learn.example</groupId>
<artifactId>com-custom-test</artifactId>
<version>1.0-SNAPSHOT</version>
<properties>
<maven.compiler.source>8</maven.compiler.source>
<maven.compiler.target>8</maven.compiler.target>
</properties>
<dependencies>
<!-- 當前模塊引入自定義場景啟動器 -->
<dependency>
<groupId>com.learn.example</groupId>
<artifactId>custom-spring-boot-starter</artifactId>
<version>1.0-SNAPSHOT</version>
</dependency>
</dependencies>
</project>
```
**2. 在當前模塊的配置文件中給自動配置模塊的properties賦值**
*`application.yml`*
```yml
custom:
config:
account:
username: zhangsan
password: 123456
```
**3. controller層調用自動配置類中的API**
```java
@RestController
public class IndexController {
@Autowired
private AccountService accountService;
@RequestMapping("/v1/auto/properties")
public AccountProperties getProperties() {
AccountProperties properties = accountService.getProperties();
System.out.println(properties);
//AccountProperties(username=zhangsan, password=123456)
return properties;
}
}
```
<br/>
通過上面的演示可以看出,com-custom-test 模塊引入了場景啟動模塊,而場景啟動器模塊又引入了自動配置模塊,所以可以在測試模塊中可以調用到自動配置類的 API。
- Mybatis
- mybatis是什么
- mybatis優缺點
- 環境搭建
- 使用步驟
- 傳參方式
- 無需傳參
- 一個參數
- 多個參數
- 增/刪/改
- 查詢
- 單表查詢
- 一對一查詢
- 一對多查詢
- 動態SQL
- 注解操作
- Spring
- Spring什么
- Spring優點
- Spring組成
- 第一個Spring程序
- 兩大核心技術
- IoC控制反轉
- IoC思想
- IoC容器使用步驟
- 屬性注入
- IoC注入方式
- 模擬IoC實現
- AOP
- AOP概念
- AOP原理
- AOP關鍵術語
- AOP編程過程
- 切入點規則
- 5種增強方式
- Spring注解開發
- 注解開發的優勢
- Bean注解開發
- AOP注解開發
- 完全注解開發
- 模擬Spring注解開發
- 自動裝配
- 配置文件拆分
- SpringBean
- Bean常用屬性
- Bean的作用域
- Bean的生命周期
- Spring整合MyBatis
- 整合步驟
- SqlSessionTemplate
- 業務層添加事務
- 事務的作用
- 配置文件事務
- 注解事務
- 事務參數
- SpringMVC
- SpringMVC是什么
- 環境搭建
- 請求流程
- 核心組件
- 前后端交互
- 簡單交互演示
- 常用注解
- 后端數據傳遞至前端
- ServletAPI
- 訪問靜態資源
- 異常處理
- HandlerExceptionResolver
- 局部異常
- 全局異常
- 轉發與重定向
- 轉發演示
- 重定向演示
- 轉發與重定向的區別
- 獲取表單數據
- 表單標簽
- REST風格的URL
- 異步處理
- 異步請求
- JSON數據處理
- 中文亂碼處理
- 日期處理
- 上傳文件
- 攔截器
- 視圖解析器
- 視圖類型
- 多視圖解析器
- 自定義pdf視圖
- JSR303數據驗證
- JSR303是什么
- 常用約束
- 使用步驟
- SpringMVC整合Mybatis
- 整合步驟
- Mybatis分頁插件
- SpringBoot
- SpringBoot是什么
- 環境搭建
- SpringBoot啟動分析
- SpringBoot啟動類
- 啟動過程
- SpringBoot配置文件
- 配置文件類型
- 更改配置文件
- 讀取配置文件
- 占位符
- 配置優先級
- 自定義IoC容器
- 定義方式
- 引入Spring配置文件
- @Configuration
- SpringBoot自動配置
- 自動配置原理
- 條件注解
- 自動配置報告
- 自定義自動配置
- 關閉自動配置
- 接管自動配置
- 多環境配置
- CommandLineRunner
- SpringBoot與Web開發
- 引入模板引擎
- Thymeleaf模板
- Freemarker模板
- 靜態資源訪問
- webjars
- 靜態資源位置
- ico圖標
- 指定首頁
- 更換Web服務器
- 國際化
- 攔截器
- 錯誤處理機制
- 錯誤處理機制原理
- 定制錯誤頁面
- 定制錯誤數據
- 上傳文件
- 注冊servlet三大組件
- 注冊Servlet
- 注冊過濾器
- 注冊監聽器
- 外部Tomcat與jsp模板
- 前后端交互
- 傳遞json字符串
- 傳遞js對象
- 傳遞表單
- 下載功能
- Swagger2文檔
- SpringBoot整合JDBC
- 整合步驟
- 核心API
- JdbcTemplate
- 增刪改
- 查詢
- NamedParameterJdbcTemplate
- 增刪改
- 查詢
- SpringBoot整合Mybatis
- 整合步驟
- 切換為Druid數據源
- 添加事務
- Mybatis分頁插件
- 場景啟動器
- 場景啟動器是什么
- 自定義場景啟動器
- SpringBoot與日志
- 日志框架
- slf4j日志
- slf4j日志實現
- 統一切換為slf4j
- 日志配置
- 日志文件
- 切換日志框架
- 切換日志場景啟動器
- SpringBoot與緩存
- JSR107緩存技術
- Spring緩存抽象
- 緩存注解
- SpEL表達式
- 使用緩存
- 自定義key生成器
- 緩存工作原理與流程
- SpringBoot整合Redis
- 整合步驟
- 初步使用
- 序列化機制
- 緩存管理器
- SpringBoot與任務
- 異步任務
- 實現異步任務
- 注意事項與原理
- 自定義線程池
- 定時任務
- cron表達式
- 創建定時任務
- @Scheduled參數
- 動態時間
- 郵件任務
- Quartz定時任務
- Quartz是什么
- 創建定時任務
- 觸發器與任務
- 任務的CURD
- 兩種觸發器
- 并發問題
- 持久化
- 任務持久化
- Quartz集群
- misfire策略
- 打包插件
- appassembler-maven-plugin
- appassembler與assembly配合