一般情况下,注入的接口为空的几种情况
一般如果启动就报接口注入异常的,notFound,很简单,
要么是应用的实现类上没有 @Service、@Componet、@Configuration、@Repository等Spring注解 等低级错误,
要么是包没有被扫描到,注解没有开启。
要么就是 在应用的Filter或Listener中使用了@Autowired ,
这个大家很容易遇到,也很容易排查。下面介绍两种 启动没问题,程序运行却报 接口NEP 错误。
非Spring上下文管理的 Bean 里面 的@autowired注入一个接口 会为空,代码如下。
@Component
public class OrderUtils {
@Autowired
ServerChannelServiceImpl serverChannelService;
void testOne(){
final OrderUtils orderUtils = new OrderUtils();
orderUtils.testOneDo(new CancelOrderDTO());
}
private void testOneDo(CancelOrderDTO cancelorderdto){
serverChannelService.cancelOrder(cancelorderdto);
}
}
很显然这里 OrderUtils 是 new 出来的一个新对象,它不被 SpringContext 管理,所以它里面也不会被注入ServerChannelServiceImpl ,解决方法也很简单,用,这里不用 new 出来的对象,用 SpringContext 获取出来即可。
第二中也是最难发现的一种。下面代码
@RestController
@RequestMapping(value = "/")
public class ChannelServiceServer {
//
@Autowired
ServerChannelService ChannelService;
@RequestMapping(value = ChannelApis.CONFIRM_ORDER, method = RequestMethod.POST)
@Loggable(descp = "接单",
orderId ="#universalChannelOrderDTO.channel_sheetno" ,
orderRrturnId = "", entId ="#universalChannelOrderDTO.ent_id" ,
channel = "#universalChannelOrderDTO.channel_keyword",
regionCode ="#universalChannelOrderDTO.region_code" ,
orderType = OrderTyprEnum.ORDER)
private ResponseDTO confirmorder(@RequestBody UniversalChannelOrderDTO universalChannelOrderDTO){
return ChannelService.confirmorder(universalChannelOrderDTO);
}
}
Loggable 是定义的一个切面注解,用于记录日志的,
此时改方法是私有的,那么这里 通过 @Autowired 注入的
ServerChannelService ChannelService;就会为null.
这里试过了,将@Autowired 换为其他的 注入注解仍然没有任何暖用。唯一的解决办法,就是将 这里私有的方法变为公有 public 。
具体分析还不是很清楚,后面再仔细看看这个问题,再更新出来,也欢迎大神留言探讨