o motivo:
O bean injetado não pode ser usado no netty, porque o NettyServerHandler é novo quando o netty é iniciado e não é entregue ao spring IOC para hospedagem
Método 1:
Você deseja completar certas operações de inicialização ao gerar o objeto, e essas operações de inicialização dependem do bean injetado, então você pode usar @PostConstruct para anotar um método init para completar a inicialização, que será automaticamente chamado após a injeção do bean ser concluída .
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 a classe de ferramentas para obter o bean necessário, chame o método do bean na classe fora do contêiner de primavera e 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);
}
}