原文地址
前言
我们常常会在公共仓库或者私有仓库维护自己的包,有时候我们的包需要从引用方获取配置文件。如果希望引用方配置文件可以使用spring的的配置,而不是写xml的配置的话,一般的方法是,使用your-lib-name-spring-boot-start加your-lib-name-spring-boot-configuration两个包完成,具体参考boot-features-developing-auto-configuration,我们这里不做过多赘述
问题
那么如果你的项目使用了这种方法但不能让引用方自动将META-INF/spring.factories中配置的且带有@Configuration的类对象放入它的springcontext中,那么应该如何解决呢。它的表现是,无法从springcontext获取配置类对象,或者你的配置类中@Bean或者@PostConstruct等方法没有没调用,需要在启动类上面使用@ComponentScan(“your.folder”)才能注入
解决
这里参考[Not able to use a config created in a java library]这个问题的答案,以及Spring Boot 2.7 Release Notes,我们可以看到,其中指出
这里支持他们已经有了新的方法去支持配置注入,但是旧的方法依旧可以注入,我之前的项目是【JDK1.8+Spring-Boot:2.7.8】的版本确实可以自动注入,可在新项目中使用同样的代码,版本为【JDK17+Spring-Boot:3.0.5】就无法注入,切换为新的配置类方式自动注入成功,新老版本区别只在于,配置文件
#META-INF/spring.factories
org.springframework.boot.autoconfigure.EnableAutoConfiguration=\
com.mycorp.libx.autoconfigure.LibXAutoConfiguration,\
com.mycorp.libx.autoconfigure.LibXWebAutoConfiguration
改为了
#META-INF/spring/org.springframework.boot.autoconfigure.AutoConfiguration.imports
com.mycorp.libx.autoconfigure.LibXAutoConfiguration
com.mycorp.libx.autoconfigure.LibXWebAutoConfiguration
注入子类由
@Configuration
@EnableConfigurationProperties({LibElseXAutoConfiguration.class, LibElseYAutoConfiguration.class})
public class LibXAutoConfiguration {
//...
}
改为了
@Import({LibElseXAutoConfiguration.class, LibElseYAutoConfiguration.class})
@Configuration
public class LibXAutoConfiguration {
//...
}
这里可能的原因是spring-boot版本在3.x之后对于之前的一些配置的沿用没有那么全面,3.x虽然已经出了蛮久的了,坑的确还是不少