背景:我们有一个阿里云公有云的产品,使用的时候需要连接用户的资源,用户出于数据安全的考虑希望我们能有一个线下版本,可以部署到他们自己的机器上,基于这个需求,我们需要将现有产品的核心逻辑代码抽离,公有云只保留接口调用,和线下版本使用相同的核心包,在此师兄建议使用springboot的starter实现。
过程:
之前没仔细研究过starter,网上有很多博客,在此我就不再赘述。在使用之后,我觉得对starter的理解可以放在整个spring容器启动的机制上来,starter是通过spring的autoconfig实现的,autoconfig读取的资源是/META-DATA/spring.factories文件。这部分在官方文档及源码上都能看到。
我想表达的是,我们理解starter可以和spring自动注入的其他方式放在一起来说,JVM加载的内容不管从哪里来,都是“资源”,原来常用的XML,现在springboot推崇的@Configuration+@Bean,以及常用的@Compenent、@Service、@Controller等等都是用来标识这是spring可以用来注入的资源的,同样spring.factories也是一种资源,它的配置信息可以指向一个@Compenent也可以指向一个@Service,也可以指向一个@Configuration @ComponentScan(basePackages = {"XXXXX"})这样的类,通过这个入口容器也能实现Bean的注入,因为我本次实现的功能有大量待注入的bean,所以使用@Configuration @ComponentScan的方式最方便。具体使用中我们可以根据使用场景选择自己适用的方法。