zoukankan      html  css  js  c++  java
  • 【原创】Springboot的Filter拦截器中使用@value获取值为null

      最近在做springboot项目时,需要使用一个Filter拦截器。在拦截器中使用@Value自动注入属性值,在本地调试没有问题,打成war包部署到tomcat中就发生获取不到值的情况,不仅是@Value,还有@Autowired应该也无法注入值。网上找了很多帖子,都说的是把Filter注册到Spring content容器内才可以用,但我依然没有测试成功。于是想了一个比较粗暴的办法--直接在静态工具类中注入值然后直接调用这个静态方法。

     原来的Filter类(tomcat无法自动获取值):

    @Slf4j
    @Component
    @WebFilter(urlPatterns={"/api/*"}, filterName="authorizationFilter")
    public class AuthorizationFilter implements Filter{
        
        @Value("${auth.appid}")
        public String appid;
    
        @Value("${auth.appsecret}")
        public String appsecret;
        
        @Override    
        public void init(FilterConfig arg0) throws ServletException {     
        } 
        
        @Override    
        public void doFilter(ServletRequest request, ServletResponse response, FilterChain chain) 
                throws IOException, ServletException {
             // 省略。。。
        }     
        
        @Override    
        public void destroy() {     
        } 
    }

      修改后(添加静态工具方法):

    @Component
    public class AuthUtil {
        
        public static String appid;
        
        public static String appsecret;
        
        private static final String HEADER_AUTH_BASIC = "Basic ";
        
        @Value("${auth.appid}")
        public void setAppid(String appid) {
            AuthUtil.appid = appid;
        }
        
        @Value("${auth.appsecret}")
        public void setAppsecret(String appsecret) {
            AuthUtil.appsecret = appsecret;
        }
        
        public static String getHeaderAuth() {
            String authPar = appid + ":" + MD5Util.MD5Encode(appsecret);
            return HEADER_AUTH_BASIC + Base64Utils.getBase64(authPar);
        }
    }
    @Slf4j
    @Component
    @WebFilter(urlPatterns={"/api/*"}, filterName="authorizationFilter")
    public class AuthorizationFilter implements Filter{
        
        @Override    
        public void init(FilterConfig arg0) throws ServletException {     
        } 
        
        @Override    
        public void doFilter(ServletRequest request, ServletResponse response, FilterChain chain) 
                throws IOException, ServletException {
            ...
            String auth = AuthUtil.getHeaderAuth();
            ...
        }     
        
        @Override    
        public void destroy() {     
        } 
    }

    其中,需要注意的是:

      1. @Value无法为静态属性注入值,所以需要添加set方法为其注入值;

      2. 工具类必须添加@Component或者@Service注解,否则@Value不起作用。

    静态方法中注入了值以后,Filter中就可以直接使用了。

    The higher I got, the more amazed I was by the view.
  • 相关阅读:
    emberjs初学记要
    自我的一点介绍(七夕礼物)
    JavaScript数据类型
    Vue+Webpack项目配置
    Git知识点整合
    Log4j简单配置解析
    如何明智地向程序员提问
    Navicat连接mysql报错1251
    多表查询sql语句
    PLSQL面向对象
  • 原文地址:https://www.cnblogs.com/wyx312/p/9887897.html
Copyright © 2011-2022 走看看