一、现象
在SpringBoot新new一个普通类,习惯性添加@Component让Spring扫描。
在@Component修饰的类里注入了其他Bean,运行时提示注入的为null
但这个Bean可以在控制层被引入,在普通类就不行。
二、解决
找了些资料,最后也没解决注入的问题。
最后的方案就是去掉@Component注解,在new这个普通类时从Spring上下文实例中取出这个Bean赋给成员变量使用。
弊端:这个类非单例
三、代码如下
ApplicationContextProvider
import org.springframework.beans.BeansException;
import org.springframework.context.ApplicationContext;
import org.springframework.context.ApplicationContextAware;
import org.springframework.stereotype.Component;
@Component
public class ApplicationContextProvider implements ApplicationContextAware {
/**
* 上下文对象实例
*/
private static ApplicationContext applicationContext;
@SuppressWarnings("static-access")
@Override
public void setApplicationContext(ApplicationContext applicationContext) throws BeansException {
this.applicationContext = applicationContext;
}
/**
* 获取applicationContext
*
* @return
*/
public static ApplicationContext getApplicationContext() {
return applicationContext;
}
/**
* 通过name获取 Bean.
*
* @param name
* @return
*/
public static Object getBean(String name) {
return getApplicationContext().getBean(name);
}
/**
* 通过class获取Bean.
*
* @param clazz
* @param <T>
* @return
*/
public static <T> T getBean(Class<T> clazz) {
return getApplicationContext().getBean(clazz);
}
/**
* 通过name,以及Clazz返回指定的Bean
*
* @param name
* @param clazz
* @param <T>
* @return
*/
public static <T> T getBean(String name, Class<T> clazz) {
return getApplicationContext().getBean(name, clazz);
}
}
IdentityCheckUtil
import io.netty.channel.ChannelHandlerContext;
import io.netty.handler.codec.http.FullHttpRequest;
import org.apache.log4j.Logger;
public class IdentityCheckUtil {
private Logger logger = Logger.getLogger(IdentityCheckUtil.class);
private UserMapper userMapper;
public IdentityCheckUtil() {
this.userMapper = ApplicationContextProvider.getBean(UserMapper.class);
}
public boolean allowedPass(ChannelHandlerContext ctx, FullHttpRequest fullHttpRequest) {
System.out.println(userMapper);
}
}