文章目录
- 1、起步依赖
- 2、自动配置
1、起步依赖
概念
起步依赖本质上是一个Maven项目对象模型(Project Object Model,POM),定义了对其他库的传递依赖,这些东西加在一起支持某一功能。
简单的说,起步依赖就是将具备某种功能的坐标打包到一起,并提供一些默认的功能
例子-搭建Web应用
Spring+SpringMVC
我们需要添加许多依赖,还要考虑到不同依赖之间存在版本冲突的问题,一般搭建一个Web项目时需要导入以下依赖:
<dependency><groupId>org.springframework</groupId><artifactId>spring-webmvc</artifactId><version>5.1.3.RELEASE</version>
</dependency><dependency><groupId>org.springframework</groupId><artifactId>spring-web</artifactId><version>5.1.3.RELEASE</version>
</dependency>
SpringBoot
搭建Web项目只需要导入一个起步依赖:
<dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-web</artifactId>
</dependency>
也就是只需要导入一个名为spring-boot-starter-web 的起步依赖即可,我们点 spring-boot-starter-web 进去可以看到,其实这个起步依赖集成了常用的 web 依赖。
2、自动配置
概念
SpringBoot的自动配置是一个运行时(应用程序启动时)的过程,根据配置,才决定Spring配置应该使用哪个,这个过程是Spring自动完成的。
分析
在SpringBoot中集成了一些常见的容器,或者说是组件,例如我们最常用的Tomcat服务器,所以在做web项目时,不需要再另外部署到Tomcat上,可以直接运行,这就需要整个项目有一个入口,类似于普通java程序中的main方法(其实就是main方法),这个入口我们一般用一个单独的类来表示,其中包含一个main方法,这个类通常称之为SpringBoot的引导类,SpringBoot入门程序的引导类代码如下:
@SpringBootConfiguration 和 @ComponentScan 注解。前者实质为 @Configuration 注解,这个注解相比大家都接触过,也就是起到声明这个类为配置类的作用,而后者起到开启自动扫描组件的作用。
这里需要重点分析的是 @EnableAutoConfiguration 这个注解,这个注解的作用是开启 Spring Boot 的自动配置功能,我们来分析一下它是如何开启的,点击进去可以看到:
可以看到这个注解上边又有两个注解,@AutoConfigurationPackage和@Import,@AutoConfigurationPackage是用来管理自动配置类的,可以先不看,先看@Import,这个注解在Spring纯注解配置当中也使用过,它的作用是导入另外一个配置类,这里导入了一个叫做AutoConfigurationImportSelector的配置类,翻译过来就是自动配置的导入选择器,进一步挖它的源代码:
由于这个类内容较多,我们只关心它实现自动配置的步骤,所以我们根据内部调用关系一步一步找:
内容太多看不懂不要紧,我们只看关键部分,这是我们找到的关键方法,第一个方法字面意思就是“选择导入”,它的内部又调用了第二个关键方法,意为“获取自动配置入口”,在这个getAutoConfigurationEntry()方法中可以明显看到configurations这样的关键字眼(通过下面的分析可以确定里面装的是一些配置类的全限定类名),而且它是一个字符串类型的集合,它来自于getCandidateConfigurations()方法,所以我们在这个类中继续往下找这个方法:
挖到这里,可以看到它还在继续调用其他类中的方法,这个时候要还想继续往下挖可能就有一定难度了,但是在这个时候我们可以从下方的message中发现一点猫腻,里面的META-INF/spring.factories好像看起来是某个路径下的,那么是那个路径下呢,我们可以盲猜就是当前这个类相关的某个路径,所以我们来到这个类的最上方看它的全限定包名:
我们可以根据这个包名在我们导入的Libraies里面去找这个包,然后真的找到了这么一个配置文件:
这个配置文件里面是一些全限定类名,而且每个类名都是以AutoConfiguration结尾的,这就基本可以确定上面那个configurations里面对应的就是这些内容,然后继续在里面找我们认识且熟悉的:
前面提到的内置Tomcat就是在这个里面进行配置的,我们通过这个全限定类名继续找到这个类:
我们通过关键注解@EnableConfigurationProperties(ServerProperties.class)继续往下挖,找到ServerProperties这个类:
可以看到这个类中定义了很多跟tomcat服务器有关的属性,如port端口、address地址等,上面有一个@ConfigurationProperties注解的属性中有一个prefix = “server”,这个其实就是对应配置文件中的前缀,那么配置文件在哪呢,我们继续回到spring.factories同级的目录下,会发现如下的一个json文件:
在这个.json文件中,可以找到跟刚才相关的配置,也就是说,这个json文件里面的值,就是SpringBoot自动配置时帮我们配置的值,如果我们需要更改这些配置,只需要在我们的配置文件中配置一下就行了,就会覆盖这里的默认配置,而使用我们的自定义配置。
SpringBoot自动配置原理的分析,到这里就基本结束了,虽然分析得比较浅薄,但是对于初学者想初步了解SpringBoot自动配置过程来说,这种深度恰到好处。等进一步熟练它的使用后,可以再进一步往底层挖掘,虽然有些太细节的东西,在项目开发中基本用不到,但是自己有一定了解的话,在使用过程中碰到问题可以有更清晰的思路去定位并解决。