使用JSP中Filter拦截器Error:Exception starting filter loginFilter

使用Filter遇到的问题

@WebFilter("/*")
public class LoginFilter implements Filter {
    @Override
    public void doFilter(ServletRequest servletRequest, ServletResponse servletResponse, FilterChain filterChain) throws IOException, ServletException {
        HttpServletRequest request = (HttpServletRequest) servletRequest;
        HttpServletResponse response = (HttpServletResponse) servletResponse;

        String requestURI = request.getRequestURI();
        Object user = request.getSession().getAttribute("user");
        if(requestURI.endsWith("index.jsp") && Objects.isNull(user)){
            response.sendRedirect("login.jsp");
            return;
        }
        filterChain.doFilter(request,response);
    }
}

上面代码模拟登录拦截,运行出现以下错误。
使用JSP中Filter拦截器Error:Exception starting filter loginFilter_第1张图片
当重写init()和destroy()方法后运行通过,然后看了下Filter里的信息

public interface Filter {
    default void init(FilterConfig filterConfig) throws ServletException {
    }

    void doFilter(ServletRequest var1, ServletResponse var2, FilterChain var3) throws IOException, ServletException;

    default void destroy() {
    }
}

init方法和destroy方法是default修饰的,是可以不用实现的。查了资料发现原因是:JDK1.7以后init()和destroy()使用了default修饰,而我用的是Tomcat7.0的maven插件,JDK是1.8版本的,Tomcat7中的Filter是老版本,init()初始化方法和destroy()销毁方法没使用default修饰,所以使用JDK1.8之前的版本或tomcat8以下的版本时需要重写init()和destroy()方法。
tomcat7换成tomcat8后运行成功。

你可能感兴趣的:(使用JSP中Filter拦截器Error:Exception starting filter loginFilter)