老师,添加filter之后一直访问不了资源,如图:
 Snipaste_2021-03-21_17-55-08.png
Snipaste_2021-03-21_17-55-08.png
老师帮忙查看一下
filter部分代码:
package com.bjsxt.web.filter;
import com.bjsxt.commons.Constants;
import com.bjsxt.pojo.User;
import javax.servlet.*;
import javax.servlet.annotation.WebServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpSession;
import java.io.IOException;
//创建过滤器
//判断用户是否进行登录的过滤器
@WebServlet(urlPatterns = {"*.do","*.jsp"})
public class UserLoginFilter implements Filter {
    @Override
    public void init(FilterConfig filterConfig) throws ServletException {
    }
    @Override
    public void doFilter(ServletRequest servletRequest, ServletResponse servletResponse, FilterChain filterChain) throws IOException, ServletException {
        //参数强制类型转换
        HttpServletRequest request = (HttpServletRequest) servletRequest;
        //获得请求的url路径
        String uri = request.getRequestURI();
        //判断当前请求是否含有login.jsp或者为login.do,如果是,就得放行,不能全部拦截,否则就是沙雕系统了
        if (uri.indexOf("login.jsp") != -1 || uri.indexOf("login.do") != -1){
            System.out.println("执行了doFilter放行1");
            filterChain.doFilter(servletRequest,servletResponse);
        } else {
            //根据session信息判断是否进行登录执行操作,若没有进行登录,则不允许访问
            HttpSession session = request.getSession();
            //获得user对象
            User user = (User) session.getAttribute(Constants.USER_SESSION_KEY);
            System.out.println("未执行");
            //进行判断
            if (user != null) {
                //进行放行
                filterChain.doFilter(servletRequest, servletResponse);
            }else {
                request.setAttribute(Constants.REQUEST_MSG,"不登录不好使~");
                //进行请求转发
                request.getRequestDispatcher("login.jsp").forward(servletRequest, servletResponse);
            }
        }
    }
    @Override
    public void destroy() {
    }
}