背景: 最近在看一些SpringBoot相关的一些源码框架,自从SpringBoot实现自动化配置后,很多框架的适配和实现对我们来说都是黑盒,我们不知道某个框架到底注册了多个容器实例,以及定位的位置在哪里,也许在某个不知名的Import导入类中定义。如果我们想知道某个Bean的定义位置和具体配置,该怎么办呢?
直接去框架starter包下面去搜,可能是找到,但是比较麻烦,毕竟一般框架自动配置要么内容繁多,要么多层嵌套。所以要想知道这个Bean更多的信息,最直接的方法就是去BeanFactory找到它的定义,就能知道我们想要的信息了。
在SpringBoot项目中,我们可以在任意接口注入ApplicationContext对象,其Context对象包含默认的DefaultListableBeanFactory实例,里面BeanDefinitionMap变量就有我们需要的内容,通过DEBUG方式,我们可以下图:
当我们在上一篇RequestContextHolder的场景中,就需要知道全局request对象是如何封装的。但我们追溯到OrderedRequestContextFilter过滤器时,再通过此方法就很容易知道去org.springframework.boot.autoconfigure.web.servlet.WebMvcAutoConfiguration.WebMvcAutoConfigurationAdapter内部类中找到此Filter注册的位置、时机和条件,这样我们就很清楚整个逻辑的来龙去脉,不至于被自动配置搞得一脸懵。
当然,此方法并不适用所有场景,如上一篇HttpServletRequest变量注入场景,在Bean实例化时被注入到控制器类,此HttpServletRequest代理对象就不在BeanDefinitionMap集合中,但是Debug方式也可以直接看到此变量的代理实现类,进而追溯其创建的源码。