统计网站的访问量的时候,用了过滤器,通过ip进行筛选,在idea中测试都没有问题,数据库数据运行正常,but部署之后,测试数据,访问量总是空,排查代码一开始以为代码有问题,后来发现本地tomcat部署之后才会出问题,进一步排查,以为tomcat获取ip有问题,进行日志输出,最后发现,过滤器没有执行,问题锁定
很奇怪的问题,boot一键启动,没有任何问题,为什么tomcat会出现问题,代码如下
@WebFilter(filterName = "xxxx")
public class CountFilter implements Filter {
private FilterConfig config;
@Override
public void init(FilterConfig filterConfig) throws ServletException {
this.config = filterConfig;
}
@Override
public void doFilter(ServletRequest servletRequest, ServletResponse servletResponse, FilterChain filterChain) throws IOException, ServletException {
System.err.println("---------------------------------------------------------------------------------- ");
System.err.println(map.size()+"========================================================================"+"ip"+ip);
filterChain.doFilter(servletRequest,servletResponse);
}
@Override
public void destroy() {
}
}
开始狂搜,看到说打war包必须要重写init()方法的,不然启动tomcat会报错,我的没有报错,而且也重写了此方法。
陷入迷茫中,转手去做别的事情,等到第二天换个心情后,终于有了新发现
最终发现一个大问题没有注入容器,加入component注解只有完美解决问题。
@Component
疑问的地方,为什么boot上可以,但是tomcat上不行呢