文章目录
- 什么是Spring Boot Starter
- 实现步骤
- 启动器
- 自动配置包
- 总结自定义Starter的实现逻辑
Spring Boot Starter官网描述:Spring Boot Starter官方介绍
什么是Spring Boot Starter
Starters可以理解为启动器,它包含了一系列可以集成到应用里面的依赖包,可以一站式集成 Spring和其他技术,而不需要到处找示例代码和依赖包。Spring Boot Starter的工作原理是:Spring Boot在启动时扫描项目所依赖的JAR包,寻找包含spring.factories文件的JAR包,根据spring.factories
配置加载AutoConfigure
类,根据@Conditional
注解的条件,进行自动配置并将Bean注入Spring Context
为什么要自定义Spring Boot Starter?
在Spring Boot官网为了简化我们的开发,已经提供了非常多场景的Starter来为我们使用,即便如此,也无法全面的满足我们实际工作中的开发场景,这时我们就需要自定义实现定制化的Starter。
实现步骤
1.首先,创建一个Maven空工程,添加两个模块
启动器
启动器中没有任何的源代码,只是告诉我们当前场景需要引入哪些依赖即可!
创建启动器模块为maven工程,命名为
xiaozhao-hello-spring-boot-starter
,对应的依赖文件
<groupId>com.zhao</groupId>
<artifactId>xiaozhao-hello-spring-boot-starter</artifactId>
<version>1.0-SNAPSHOT</version>
自动配置包
自动配置包中实现了所有的自动配置功能!
创建自动配置包模块为SpringBoot初始化工程,命名为xiaozhao-hello-spring-boot-starter-autoconfigure
最终的项目模块如下:
2.模块创建完成后,需要在启动器中引入自动配置模块(别人引入场景启动器,自动配置包就会自动引入)
<dependencies><dependency><groupId>com.zhao</groupId><artifactId>xiaozhao-hello-spring-boot-starter-autoconfigure</artifactId><version>0.0.1-SNAPSHOT</version></dependency>
</dependencies>
3.编写自动配置模块。
- 创建自定义的Properties文件
@ConfigurationProperties("xiaozhao.hello")
public class HelloProperties {private String prefix;private String suffix;public String getPrefix() {return prefix;}public void setPrefix(String prefix) {this.prefix = prefix;}public String getSuffix() {return suffix;}public void setSuffix(String suffix) {this.suffix = suffix;}
}
- 创建业务类读取Properties文件中的值
public class HelloService {@AutowiredHelloProperties helloProperties;public String sayHello(String userName){return helloProperties.getPrefix() + ":" + userName + ">" + helloProperties.getSuffix();}
}
- 再个自动配置类,自动进行类加载
@Configuration
@ConditionalOnMissingBean(HelloService.class)
@EnableConfigurationProperties(HelloProperties.class)
public class HelloServiceAutoConfiguration {@Beanpublic HelloService helloService(){HelloService helloService = new HelloService();return helloService;}
}
最终的效果如下:
4.在resources
目录下创建META-INF/spring.factories添加如下配置信息
org.springframework.boot.autoconfigure.EnableAutoConfiguration=\
com.zhao.hello.auto.HelloServiceAutoConfiguration
5.装hello-spring-boot-starter-autoconfigure
模块和xiaozhao-hello-spring-boot-starter
6.装完成后,创建新的项目来引入创建好的starter.新的的项目名为hello-test
的Spring Boot初始化项目。
引入我们之前定义的Starter启动器和Spring Boot自带的Web启动器
<dependencies><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-web</artifactId></dependency><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-test</artifactId><scope>test</scope></dependency><dependency><groupId>com.zhao</groupId><artifactId>xiaozhao-hello-spring-boot-starter</artifactId><version>1.0-SNAPSHOT</version></dependency>
</dependencies>
7.在hello-test
项目中创建测试Controller
@RestController
public class HelloController {@AutowiredHelloService helloService;@GetMapping("/hello")public String sayHello() {String str = helloService.sayHello("李四");return str;}
}
编写配置文件
xiaozhao.hello.prefix=hello
xiaozhao.hello.suffix=666
8.启动项目,测试一下
总结自定义Starter的实现逻辑
- 首先引入自定义的Starter:
xiaozhao-hello-spring-boot-starter
,在这个Starter中引入自定义的自动配置场景 - 当自动配置场景启动时,会去寻找spring.factories文件,去自动加载
HelloServiceAutoConfiguration
类文件 - 加载完自动配置类后,
@ConditionalOnMissingBean(HelloService.class)
通过这个注解,当容器中没有HelloService
时,去自动添加一个HelloService
组件。 HelloService
组件的所有属性,通过HelloPropertie
s配置文件进行绑定的,@ConfigurationProperties("xiaozhao.hello")
,通过xiaozhao.hello。xxx
进行绑定。- 如果自己在容器中注入一个
HelloService
组件,使用的就不是自动配置的,而是重新注入的。