最近在作springboot項目時,須要使用一個Filter攔截器。在攔截器中使用@Value自動注入屬性值,在本地調試沒有問題,打成war包部署到tomcat中就發生獲取不到值的狀況,不只是@Value,還有@Autowired應該也沒法注入值。網上找了不少帖子,都說的是把Filter註冊到Spring content容器內才能夠用,但我依然沒有測試成功。因而想了一個比較粗暴的辦法--直接在靜態工具類中注入值而後直接調用這個靜態方法。spring
原來的Filter類(tomcat沒法自動獲取值):api
@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() { } }
修改後(添加靜態工具方法):tomcat
@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() { } }
其中,須要注意的是:springboot
1. @Value沒法爲靜態屬性注入值,因此須要添加set方法爲其注入值;app
2. 工具類必須添加@Component或者@Service註解,不然@Value不起做用。ide
靜態方法中注入了值之後,Filter中就能夠直接使用了。工具