1.自动装配原理
1.1 依赖管理
父项目做依赖管理
<parent>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-parent</artifactId>
<version>2.3.4.RELEASE</version>
</parent>
他的父项目:
<parent>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-dependencies</artifactId>
<version>2.3.4.RELEASE</version>
</parent>
在这里面几乎声明了所有开发中常用的依赖的版本号,自动版本仲裁机制
如果需要更改版本号:
- 首先查看spring-boot-dependencies里面规定当前依赖的版本
- 在当前项目重写配置
- 比如规定是8版本的Mysql,如果需要5版本的Mysql则
<properties>
<mysql.version>5.1.43</mysql.version>
</properties>`
1.2 Pom.xml
- springboot-boot-starter-xxx:spring-boot的场景启动器
- SpringBoot将所有的功能场景都抽取出来,做成一个个的starter (启动器),只需要在项目中引入这些starter即可,所有相关的依赖都会导入进来
- xxx-springboot-boot-starter:第三方
- 所有场景启动器最底层的依赖:
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter</artifactId>
<version>2.3.4.RELEASE</version>
<scope>compile</scope>
</dependency>
1.3 自动装配
- 自动配置好Tomcat
- 自动引入Tomcat依赖
- 自动引入Tomcat依赖
- 自动配好SpringMVC
- 引入SpringMVC全套组件
- 自动配好Web常见功能(字符编码等)
• 默认的包结构
• 主程序所在包及其下面的所有子包里面的组件都会被默认扫描进来
• 无需以前的包扫描配置
• 想要改变扫描路径,在主程序开始添加
@SpringBootApplication(scanBasePackages=“com.node”)
或者@ComponentScan 指定扫描路径 - 按需加载所有自动配置项
- SpringBoot所有的自动配置功能都在 spring-boot-autoconfigure 包里面
- SpringBoot所有的自动配置功能都在 spring-boot-autoconfigure 包里面
1.3 主启动类
1.3.1@SpringBootApplication(主配置类)
1.3.1.2 @SpringBootConfiguration
SpringBoot的配置类
1.3.1.3 @EnableAutoConfiguration
开启自动配置功能:自动导入包
1.3.1.3.1 核心一:@AutoConfigurationPackage
@Import({Registrar.class})
public @interface AutoConfigurationPackage {
}
//利用Registrar给容器中导入一系列组件
//将指定的一个包下的所有组件导入进来?MainApplication 所在包下。
由此可知,Registrar返回的是com.node.boot.controller包下面的所有组件打包成数组,并导入进配置。
(MainApplication所在包下–>com.node.boot下)
1.3.1.3.2 核心二:@Import({AutoConfigurationImportSelector.class})
1.利用getAutoConfigurationEntry(annotationMetadata);给容器中批量导入一些组件
2.调用List configurations = this.getCandidateConfigurations(annotationMetadata, attributes);获取到所有需要导入到容器中的配置类
4.利用工厂加载 Map<String, List> loadSpringFactories(@Nullable ClassLoader classLoader);得到所有的组件
spring-boot-autoconfigure-2.3.4.RELEASE.jar/META-INF/spring.factories
文件里面写死了spring-boot一启动就要给容器中加载的所有配置类
虽然我们127个场景的所有自动配置启动的时候默认全部加载。xxxxAutoConfiguration
按照条件装配规则(@Conditional),最终会按需配置。
1.3.1.4 @ComponentScan
扫描当前主启动类同级的包
1.3 定制化配置
SpringBoot默认会在底层配好所有的组件。但是如果用户自己配置了以用户的优先
1.3.1 方法一
如果自己想要配置编码格式,则在自己的Myconfig类中配置以下
@Bean
@ConditionalOnMissingBean
public CharacterEncodingFilter characterEncodingFilter() {
}
1.3.2 方法二
用户去看这个组件是获取的配置文件什么值就去修改。
比如修改编码
在application.properties中修改
总结:改配置文件流程:从xxxAutoConfiguration–>导入了组件—>又从xxxxProperties拿值–>从application.properties获取
1.4 如何看
每个自动配置类按照条件进行生效,默认都会绑定配置文件指定的值。xxxxProperties里面拿。xxxProperties和配置文件进行了绑定
1.5 结论
- 自动配置是从classpath中搜寻所有的META-INF/spring.factories配置文件 ,并将其中对应的依赖包下的配置项,通过反射实例化为对应标注了@Configuration的JavaConfig形式的IOC容器配置类 , 然后将这些都汇总成为一个实例并加载到IOC容器中。
- SpringBoot在启动的时候从类路径下的META-INF/spring.factories中获取
EnableAutoConfiguration指定的值。 - 将这些值作为自动配置类导入容器 ,帮我们进行自动配置工作。
- 它会给容器中导入非常多的自动配置类 (xxxAutoConfiguration),并配置好这些组件、
- 不需要我们手动编写配置注入功能组件等的工作,提高了工作效率。
- 每个自动配置类按照条件进行生效,默认都会绑定配置文件指定的值。xxxxProperties里面拿。xxxProperties和配置文件进行了绑定
- 改配置文件流程:从xxxAutoConfiguration–>导入了组件—>又从xxxxProperties拿值–>从application.properties获取
- 一句话:按需加载,条件装配
2.SpringApplication启动类
SpringApplication.run(SpringbootTest1HelloApplication.class, args);
- 推断应用的类型是普通的项目还是Web项目
- 查找并加载所有可用初始化器 , 设置到initializers属性中
- 找出所有的应用程序监听器,设置到listeners属性中
- 推断并设置main方法的定义类,找到运行的主类