首先需要对Spring boot的加载流程有一定的了解。
我们在maven里经常会写诸如 spring-boot-starter-xxx 的依赖,由于只要引入了这样的依赖,其相应的版本无需多余指定,也无需写多余的扫描和加载注解,即可立即使用,称为开箱即用。
从maven的spring-boot-starter出发,点进去我们会看到一些引用。
从名称上看,让开箱即用起作用的是spring-boot-autoconfigure.jar,在这个包之中,我们会看到已对接了的众多带有starter的工具,包括spring自家的和其他第三方的,比如spring-boot-starter-web下引用的spring-boot-starter-json,我们知道只要引用了spring-boot-starter-web就自然而然会带着json,在json包下会找到JacksonAutoConfiguration
这个类。
再比如其他的,
他们这些XxxAutoConfiguration类的共同注解有@AutoConfiguration
和@ConditionalOnClass
,我们先来看看@ConditionalOnClass
。
只有在classpath中声明使用了某些类才会生效,换句话说,只有引用了相应的jar包才会用@AutoConfiguration
进行自动配置。
再说@AutoConfiguration
,将会由SpringFactoriesLoader
负责从classpath中的诸多jar包文件中寻找META-INF/spring.factories来读取并实例化这些被这个注解标记的类。
另外还有一个ImportCandidates
,它也会自动加载配置,只要是META-INF/spring/下任意的.imports文件。
项目启动类的注解@SpringBootApplication
是三个注解的集合,其中一个是@EnableAutoConfiguration
,两者配合在一起使用才能使自动配置加载生效。@EnableAutoConfiguration
上有@Import(AutoConfigurationImportSelector.class)
注解,这个AutoConfigurationImportSelector
类通过读取META-INF/spring.factories配置来决定加载什么。