一、先实现Filter接口,重写doFilter方法
import crm.workbench.demo.User;
import javax.servlet.*;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import javax.servlet.http.HttpSession;
import java.io.IOException;
public class LoginFilter implements Filter {
@Override
public void init(FilterConfig filterConfig) throws ServletException {
System.out.println("LoginFilter已被初始化!");
}
@Override
public void doFilter(ServletRequest request, ServletResponse response, FilterChain chain) throws IOException, ServletException {
System.out.println("进入到验证有没有登录过的过滤器");
HttpServletRequest req = (HttpServletRequest) request;
HttpServletResponse res = (HttpServletResponse) response;
String path = req.getServletPath();
System.out.println("path="+path);
//不应该被拦截的资源,自动放行请求
if("/login.html".equals(path) || "/login.do".equals(path)){
chain.doFilter(request, response);
//其他资源必须验证有没有登录过
}else{
HttpSession session = req.getSession();
User user = (User) session.getAttribute("user");
//如果user不为null,说明登录过
if(user!=null){
chain.doFilter(request, response);
//没有登录过
}else{
//重定向到登录页
/*
重定向的路径怎么写?
在实际项目开发中,对于路径的使用,不论操作的是前端还是后端,应该一律使用绝对路径
关于转发和重定向的路径的写法如下:
转发:
使用的是一种特殊的绝对路径的使用方式,这种绝对路径前面不加/项目名,这种路径也称之为内部路径
/login.jsp
重定向:
使用的是传统绝对路径的写法,前面必须以/项目名开头,后面跟具体的资源路径
/crm/login.jsp
为什么使用重定向,使用转发不行吗?
转发之后,路径会停留在老路径上,而不是跳转之后最新资源的路径
我们应该在为用户跳转到登录页的同时,将浏览器的地址栏应该自动设置为当前的登录页的路径
*/
res.sendRedirect(req.getContextPath() + "/login.html");
}
}
}
@Override
public void destroy() {
System.out.println("LoginFilter已被销毁!");
}
}
二、使用Spring配置容器注册
import crm.filter.LoginFilter;
import org.springframework.boot.web.servlet.FilterRegistrationBean;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
@Configuration
public class FilterConfig {
/**
* 注入Filter
* @return
*/
@Bean
public FilterRegistrationBean filter() {
FilterRegistrationBean registration = new FilterRegistrationBean();
registration.setFilter(new LoginFilter());
//设置过滤路径可以多个
registration.addUrlPatterns("*.html");
registration.addUrlPatterns("*.do");
registration.setName("filter");
//设置优先级别
registration.setOrder(1);
return registration;
}
}