7、Filter

1、过滤器的作用

在执行客户端到服务器端的过程中,会先经过filter(过滤器),在过滤器执行相应的处理操作,比如登录权限验证、编码设置,可以解决controller中共性代码的冗余问题。

2、springboot实现过滤

1、编写java类实现Filter接口

2、在doFilter()方法中编写拦截逻辑

3、设置拦截路径  @WebFilter("/拦截路径")

4、在启动类添加  @ServletComponentScan

3、实现例子

@WebFilter("/study/*")
public class TestFilter implements Filter {

    @Override
    public void doFilter(ServletRequest servletRequest, ServletResponse servletResponse, FilterChain filterChain) throws IOException, ServletException {
        System.out.println("进入过滤");

        //放行过滤
        filterChain.doFilter(servletRequest,servletResponse);

        //从服务器向客户端响应
        System.out.println("再次经过过来,结束过滤");
    }
}

4、拦截路径,拦截的三种形式

1、精确拦截:/index.jsp、/myservlet

2、后缀拦截: * .jsp、* . html、* .jpg

3、通配符拦截:/aaa/bbb/ *、 *
  • 总体实现例子

  • 案例是实现登录验证,判断改用户是否已登录,

    1、如果已登录放行,如果未登录,响应给前端,让前端拿到标识后做跳转处理

    2、对于相应的页面做放行处理,避免把所有页面都拦截下来

@WebFilter(filterName = "loginCheckFilter",urlPatterns = "/*")
@Slf4j
public class LoginCheckFilter2 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、获取本次请求的URI
        String requestURI = request.getRequestURI();// /backend/index.html

        log.info("拦截到请求:{}",requestURI);

        //定义不需要处理的请求路径
        String[] urls = new String[]{
                "/employee/login",
                "/employee/logout",
                "/backend/**",
                "/front/**"
        };


        //2、判断本次请求是否需要处理
        boolean check = check(urls, requestURI);

        //3、如果不需要处理,则直接放行
        if(check){
            log.info("本次请求{}不需要处理",requestURI);
            filterChain.doFilter(request,response);
            return;
        }

        //4、判断登录状态,如果已登录,则直接放行
        if(request.getSession().getAttribute("employee") != null){
            log.info("用户已登录,用户id为:{}",request.getSession().getAttribute("employee"));
            filterChain.doFilter(request,response);
            return;
        }

        log.info("用户未登录");
        //5、如果未登录则返回未登录结果,通过输出流方式向客户端页面响应数据
        response.getWriter().write(JSON.toJSONString(Response.fail(0,"NOTLOGIN")));
        return;

    }

    /**
     * 路径匹配,检查本次请求是否需要放行
     * @param urls
     * @param requestURI
     * @return
     */
    public boolean check(String[] urls,String requestURI){
        for (String url : urls) {
            boolean match = PATH_MATCHER.match(url, requestURI);
            if(match){
                return true;
            }
        }
        return false;
    }
        }

 








posted @ 2022-07-12 16:40  jason饼干大怪兽  阅读(93)  评论(0)    收藏  举报