filter是对原本请求的拦截
filterChain.doFilter(req,resp)相当于通过过滤器之后,继续执行原本请求;
而以上的if else同样包括转发请求,肯定会执行一次,之后的原本请求也会执行一次;
也就是说原本只有一个请求,现在却变成了两个!!!
所以,必须要保证最后只有一个请求跳出去。
// 获取login页面传来的用户名+密码 String username = req.getParameter("username"); String password = req.getParameter("password"); User user = qAser.getUser(username); // 检查用户、密码 if (user == null || !user.getPassword().equals(password)) { System.out.println("用户名或密码错误,请重新登陆!"); resp.sendRedirect("/quiz_war_exploded/error"); }else{ System.out.println("登陆成功"); filterChain.doFilter(req,resp); }