la razón:
El bean inyectado no se puede usar en netty, porque NettyServerHandler es nuevo cuando se inicia netty, y no se entrega a Spring IOC para hospedaje
Método 1:
Desea completar ciertas operaciones de inicialización cuando genera el objeto, y estas operaciones de inicialización dependen del bean inyectado, por lo que puede usar @PostConstruct para anotar un método de inicio para completar la inicialización, que se llamará automáticamente después de que se complete la inyección del bean .
public class NettyServerHandler extends ChannelInboundHandlerAdapter {
@Autowired
private RedisService redisService;
private static NettyServerHandler nettyServerHandler;
@PostConstruct
public void init() {
nettyServerHandler = this;
}
@Override
public void channelActive(ChannelHandlerContext ctx) {
nettyServerHandler.redisService.getString()
}
//。。。。。。。。。以下部分省略
}
Método 2:
Use la clase de herramienta para obtener el bean requerido, llame al método bean en la clase fuera del contenedor de primavera y coloque NettyOperate nettyOperate = SpringUtils.getBean (NettyOperate.class);
import org.springframework.beans.BeansException;
import org.springframework.context.ApplicationContext;
import org.springframework.context.ApplicationContextAware;
import org.springframework.stereotype.Component;
/**
* 获取StringBean必须要加入到容器中
*/
@Component
public class SpringUtils implements ApplicationContextAware {
private static ApplicationContext applicationContext;
/**
* 重写父类方法
* @param applicationContext
* @throws BeansException
*/
@Override
public void setApplicationContext(ApplicationContext applicationContext) throws BeansException {
if(SpringUtils.applicationContext == null){
SpringUtils.applicationContext = applicationContext;
}
}
public static ApplicationContext getApplicationContext() {
return applicationContext;
}
public static Object getBean(String name){
return getApplicationContext().getBean(name);
}
public static <T> T getBean(Class<T> clazz){
return getApplicationContext().getBean(clazz);
}
}