Spring boot 无法注入service
SpringBoot项目的Bean装配默认规则是根据Application类所在的包位置从上往下扫描!
“Application类”是指SpringBoot项目入口类。
这个类的位置很关键:
如果Application类所在的包为:com.boot.app,则只会扫描com.boot.app包及其所有子包,如果service或dao所在包不在com.boot.app及其子包下,则不会被扫描!
即,把Application类放到dao、service所在包的上级,com.boot.Application
知道这一点非常关键,大多数情况下bean无法注入进来都是这个原因引起的。
附上正确目录结构
@Autowired注入无法实例化service
问题场景
springboot整合netty时,netty的处理类无法实例化service
问题解读
经过查阅资料,netty的bean对象默认不交由spring管理
解决方案
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
|
@Component //1.添加注解 public class NettyServerHandler extends ChannelInboundHandlerAdapter { private static Log log = LogFactory.getLog(NettyServerHandler. class ); @Autowired private RedisUtils redisUtils; //2.声明本类 private static NettyServerHandler nettyServerHandler; //3.声明构造方案 public NettyServerHandler(){} //4.添加注解,在项目初始化时执行这个方法 @PostConstruct public void init() { nettyServerHandler = this ; nettyServerHandler.redisUtils = this .redisUtils; } ===================================== 经过以上 4 步骤的处理 for (Map dto : variants){ String key = dto.get( "key" ).toString(); nettyServerHandler.redisUtils.hmset(dto.get( "key" ).toString(), dto, 100000 ); } //nettyServerHandler.redisUtils.hmset() 通过这种方式调用redisUtils就可以了 |
@PostConstruct 描述
@PostConstruct
从Java EE5规范开始,Servlet增加了两个影响Servlet生命周期的注解(Annotation):@PostConstruct和@PreConstruct。这两个注解被用来修饰一个非静态的void()方法.而且这个方法不能有抛出异常声明。 @PostContruct是spring框架的注解,在方法上加该注解会在项目启动的时候执行该方法,也可以理解为在spring容器初始化的时候执行该方法。
@PostConstruct在项目中的用处
@PostConstruct注解的方法在项目启动的时候执行这个方法,也可以理解为在spring容器启动的时候执行,可加载项目中常规数据。
spring中Constructor、@Autowired、@PostConstruct的顺序
要将对象b注入到对象a,那么首先就必须得生成对象b与对象a,才能执行注入。所以,如果一个类a中有个成员变量b被@Autowired注解,那么@Autowired注入是发生在a的构造方法执行完之后的。
如果想在生成对象时候完成某些初始化操作,而偏偏这些初始化操作又依赖于依赖注入,那么就无法在构造函数中实现。为此,可以使用@PostConstruct注解一个方法来完成初始化,@PostConstruct注解的方法将会在依赖注入完成后被自动调用。
Constructor >> @Autowired >> @PostConstruct
以上为个人经验,希望能给大家一个参考,也希望大家多多支持服务器之家。
原文链接:https://blog.csdn.net/daxiang52/article/details/79310889