一、前言
上一篇 《spring-boot-devtools配置和原理》 讲到当我们要去了解一个Jar如何被调用,会去查阅spring.factories这个配置文件。spring.factories配置机制类似于Java SPI,META-INF/spring.factories 文件中配置了接口实现类名称,然后springboot在启动时候扫描该配置文件并实例化配置文件中的Bean. SPI可以参考《SPI机制详解》这篇文章。
二、spring.factories简单使用
1、创建一个测试类
注:在实例化的时候输出日志
2、META-INFO/spring.factories
3、SpringBoot启动时
注:可以看出TestBean在SpringBoot启动时进行了实例化。
三、Spring.factories原理
通常将Bean注入到Spring容器中有多种方法,比如@Autowire、@import注解,而Spring.factoires的意义在于可以将第三方Jar包中的Bean有选择地注入到容器中。
SpringFactoriesLoader用于将类注入到Spring容器,关键代码如下:
注:通过【1】的代码将META-INFO下factories实现类定义名称解析出来,通过【2】的代码加载到容器中。
注:【1】获取META-INFO下spring.factories文件,【2】遍历文件中key/value的定义(支持一个接口定义多个实现)加载到Map<String,List<String>>.
在Springboot很多包中都可以找到spring.factories,比如spring-boot-test。
在日常工作中,我们要实现SDK给别人用就可以使用Factories机制,这样就可以让使用者只需要很少甚至不需要配置就可以使用我们提供的Jar包。
注:下一篇讲Springboot的starte机制。