用@WebFilter注解来定义一个过滤器,名为"loginCheckFilter"。该过滤器将应用于所有URL模式("/*"表示匹配所有URL),以进行登录验证。
步骤如下:
- 获取本次请求的URL,定义不需要处理的请求路径
- 判断本次请求是否需要处理
- 如果不需要处理,直接放行
- 判断是否已登录,如果已登录直接放行
- 返回未登录结果,通过输出流方式向客户端响应数据
@Slf4j
@WebFilter(filterName = "loginCheckFilter", urlPatterns = "/*")
public class LoginCheckFilter implements Filter {
//路径匹配,支持通配符
public 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;
//1.获取本次请求的URL
String requestURL = request.getRequestURI();
log.info("拦截到请求:{}", request.getRequestURI());
//定义不需要处理的请求路径
String[] urls = new String[]{
"/employee/login",
"/emplyoee/logout",
"/backend/**",
"/front/**"
};
//2.判断本次请求是否需要处理
boolean check = check(urls, requestURL);
//3.如果不需要处理,则直接放行
if (check) {
log.info("本次请求{}不需要处理",request);
filterChain.doFilter(request, response);
return;
}
//4.判断登录状态,如果已登录,则直接放行
if (request.getSession().getAttribute("employee") != null) {
log.info("用户已登录,用户id为{}",request.getSession().getAttribute("employee"));
filterChain.doFilter(request,response);
return;
}
//5.如果未登录则返回未登录结果,通过输出流方式向客户端页面响应数据
log.info("用户未登录");
response.getWriter().write(JSON.toJSONString(R.error("NOTLOGIN")));
return;
}
/**
* @param urls
* @param requestURL
* @return
*/
public boolean check(String[] urls, String requestURL) {
for (String url : urls) {
boolean match = PATH_MATCHER.match(url, requestURL);
if (match) {
return true;
}
}
return false;
}
}
该文章介绍了如何使用Java的@WebFilter注解创建一个名为loginCheckFilter的过滤器,该过滤器应用于所有URL以进行登录检查。过滤器首先排除特定的URL路径,然后检查用户是否已登录。如果用户未登录,会返回未登录的错误信息。
304





