@WebFilter(filterName = "loginCheckFilter", urlPatterns= "/*")//过滤所有请求
public class LoginCheckFilter implements Filter {
// 路径匹配器,支持通配符
private static final AntPathMatcher PATH_MATCHER = new AntPathMatcher();
@Override
public void doFilter(ServletRequest servletRequest, ServletResponse servletResponse, FilterChain filterChain) throws IOException, ServletException {
HttpServletRequest request = (HttpServletRequest) servletRequest;
HttpServletResponse response = (HttpServletResponse) servletResponse;
// 获取本次请求的URI
String requestURI = request.getRequestURI();
String[] urls = new String[]{
"/employee/login",
"/employee/logout",
"/backend/**",
"/front/**"
};
// 判断本次请求, 是否需要登录, 才可以访问
if (check(urls,requestURI)){
filterChain.doFilter(request,response);
return;
}else {
// 判断登录状态,如果已登录,则直接放行
if(request.getSession().getAttribute("employee")!=null){
Employee employee = (Employee)request.getSession().getAttribute("employee");
filterChain.doFilter(request,response);
return;
}else {
// 如果未登录, 则返回未登录结果
response.getWriter().write(JSON.toJSONString(R.error("NOTLOGIN")));
}
}
}
public boolean check(String[] urls,String requestURI) {
for (String url : urls) {
boolean match = PATH_MATCHER.match(url, requestURI);
if (match){
return true;
}
}
return false;
}
}
【笔记】过滤器
最新推荐文章于 2024-05-09 08:44:40 发布