springboot的自动装配就是通过自定义实现importSelector接口,
从而导致项目启动时会自动将所有项目META-INF/spring.factories文件中所配置的配置类注入到spring容器中,从而实现了自动装配。
我们去查看springBoot的源码,在项目启动类上有一个注解@SpringBootApplication,点进去
,有一个@EnableAutoConfiguration注解,继续点进去,有一个@Import(AutoConfigurationImportSelector.class)注解,
@Import注解就是给spring容器导入了一些组件,这里传入了一个组件选择器 AutoConfigurationImportSelector,
里面有一个selectImport方法,将所有需要导入的组件以全类名的方式返回。
这些组件就会被加入到容器中。
还有一些比较重要的方法,getAutoConfigurationEntity,这个方法里就是自动装配的逻辑,
点进去,会看到它在加载配置,它在加载一些类,通过SpringFactoriesLoader.loadFactoryNames();
这个方法扫描所有jar包类路径下META-INF/spring.factories文件,
把扫描到的这些文件内容包装成properties对象,
从properties中获取到EnableAutoConfiguration指定的值,
将这些值作为自动配置类导入到容器中,自动配置类就生效了,帮我们进行自动配置工作。
【java|springBoot自动装配原理】以前spring开发都需要我们自己配置,现在自动配置类都帮我们完成了。
推荐阅读
- linux|zookeeper-3.4.14 出现 Client port found: 2181. Client address: localhost. 的解决办法
- java|spring boot报错org.springframework.context.ApplicationContextException:Unable to start Embedded
- Java|Java 8(JDK 1.8)升级更新至 Java 11(JDK 11)/ Java 17(JDK 17)LTS
- java|Spring框架漏洞总结
- spring|Spring Boot Actuator 漏洞复现合集
- spring|【网络安全】Spring框架漏洞总结(一)
- Spring学习|Spring boot项目Fortify漏洞扫描问题解决
- 框架漏洞|Spring MVC漏洞合集
- 安全|【组件攻击链】一文看懂Spring全家桶各类RCE漏洞