首页 > 编程语言 > 详细

关于 springboot 过滤器中使用@Autowired 为空 以及 使用 @Value 无法读取yml配置的问题解决

时间:2020-07-16 13:00:46      阅读:83      评论:0      收藏:0      [点我收藏+]

前言

最近在负责做鉴权认证这一块,初学遇到很多问题,特别是天天都出现的空指针异常。
废话不多说,说说我遇到的问题。

....
@Slf4j
public class JWTAuthorizationFilter extends BasicAuthenticationFilter {
    @Autowired
    private SysUserDao sysUserDao;
    ....



问题1 :在过滤器中使用 @Autowired 为null

经过百度之后,知道

Spring中,web应用启动的顺序是:listener->filter->servlet,先初始化listener,然后再来就filter的初始化,再接着才到我们的dispathServlet的初始化,因此,当我们需要在filter里注入一个注解的bean时,就会注入失败,因为filter初始化时,注解的bean还没初始化,没法注入。

简答理解:过滤器的生命优先级比较高,还没加载后面的bean之类的东西,spring无法帮你注入

解决方法:

1 //获取容器
2 ServletContext context = request.getServletContext();
3 ApplicationContext ctx = WebApplicationContextUtils.getWebApplicationContext(context);
4 
5 bean xxx = ctx.getBean(bean.class);

 



问题2:过滤器使用 @Value 为null

使用过多种方法,我的大概理解和上面的原因一样,不知道对不对,有没有高手指错。
问了小伙伴之后,推荐我去用 Environment

百度之后知道:

Environment 用来表示整个应用运行时的环境,为了更形象地理解Environment,你可以把Spring应用的运行时简单地想象成两个部分:一个是Spring应用本身,一个是Spring应用所处的环境。

如此一来可以简单试试看,利用上面的方法获取bean,然后读取yml文件:

Environment environment = ctx.getBean(Environment.class);

String jasyptSecretKey = environment.getProperty("jwt.secretkey");


————————————————
版权声明:本文为CSDN博主「我想吃猪蹄」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。
原文链接:https://blog.csdn.net/weixin_38936572/article/details/105076249

关于 springboot 过滤器中使用@Autowired 为空 以及 使用 @Value 无法读取yml配置的问题解决

原文:https://www.cnblogs.com/Bruce_H21/p/13321686.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!