在项目中遇到了该问题,纠结了不少的时间。特此记录。
先说一下对该问题的理解。为什么在抽象类中无法注入bean?根本原因在于抽象类无法实例化。spring的原理是在启动服务器的时候读取配置文件,取得类名后在spring的上下文中生成一个单例的对象,在由spring注入其中所需要的bean。抽象类在反射生成对象的时候就已经失败,所以也就不可能为其中的bean注入属性。
在说下该问题产生的背景:仓库管理系统中,有各种各样的费用问题,比较的繁琐。目前在项目中用到了7中不同的收费项,还有待收录的对象有26中。而且每种的收费项都有自己针对的使用场景,所以需要单独的对每一种收费项进行处理。很直接的就想到了编写一个抽象类,把其中所需要公共的部分抽离出来,每种单独的收费项项只处理计算问题。由于计费项和业务问题紧密相关,就需要引入不同的Service层的bean。一开始还没有注意该问题,等到调试接口的时候才发现存在空指针异常,bean一直无法注入。
在说下解决的方法,不能自动注入就不自动注入了。直接使用spring上下文工厂在生成一个对象。直接在抽象类中使用。如下的方式:
ApplicationContext中的getBean();
这样就可以解决了。