起因
开发过程中在过滤器(filter)中注入Bean出现空指针异常,通过查找资料了解空指针的原因,特此记录。
问题分析
由于其他bean在service,controller层注入一点问题也没有,开始根本没意识到Bean无法注入是在拦截器中无效的问题。
- SpringBoot项目的Bean装配默认规则是根据Application类所在的包位置从上往下扫描!
“Application类”是指SpringBoot项目入口类。这个类的位置很关键:
如果Application类所在的包为:com.root.app,则只会扫描com.root.app包及其所有子包,如果service或dao所在包不在com.root.app及其子包下,则不会被扫描!
即, 把Application类放到dao、service所在包的上级,com.root.Application
我出问题的类确实在Application类子包下面,排除此项。 - 意识到只是拦截器(或过滤器)上会有这样的问题,查询原因应该是:
拦截器执行在自动bean初始化之前导致这个问题的。
Spring web中各个元素的初始化顺序
在web.xml中各个元素的执行顺序:
context-param–>listener–>filter–>servlet
而拦截器是在Spring MVC中配置的,如果从整个项目中看,一个servlet请求的执行过程就变成了这样