自定义过滤器实现简单的登录

1-过滤器是什么?

在项目编写的过程中,往往有这样的需要,登录,参数校验,定义编码格式…这些都是在进入控制层之前需要完成的,过滤器就起着这样的作用,在请求进入控制层之前,对请求进行一些处理,在控制层执行完之后,也可以对返回的结果进行相应的处理.
请添加图片描述

2-如何自定义过滤器实现登录?

2-1 定义类实现java已有的filter接口



/**
 * 自定义登录过滤器
 */
@WebFilter(filterName = "loginFilter",urlPatterns = "/*")   // 声明一个过滤器,定义名字和拦截路劲
public class LoginFilter implements Filter {

2-2 实现里面的方法,重点是dofilter方法

@Override
    public void doFilter(ServletRequest servletRequest, ServletResponse servletResponse, FilterChain filterChain) throws IOException, ServletException {
        System.out.println("================================过滤器");
        HttpServletRequest request = (HttpServletRequest) servletRequest;
        HttpServletResponse response = (HttpServletResponse) servletResponse;
        String requestURI = request.getRequestURI();
        System.out.println(requestURI);
        // 检验在白名单中就放行,不在就拦截
        if(check(urls,requestURI)){
            System.out.println("白名单不需要拦截");
            filterChain.doFilter(request,response);// 放行
            return;
        }
        // 用户登录过了,也不需要拦截
        HttpSession session = request.getSession();
        if(session.getAttribute("userInfo") != null){
            filterChain.doFilter(request,response);// 放行
            return;
        }
        response.sendRedirect("/user/login");   // 不在白名单也没登录就跳转到登录页面
    }

2-3 启动类加上注解扫描webfilter,使过滤器生效


@SpringBootApplication
@MapperScan(value = "com.lt.mapper")
@ServletComponentScan // 这个注解会扫描将webfilter标记的注册到spring容器从而使filter生效
public class StudentApp {
    public static void main(String[] args) {
        SpringApplication.run(StudentApp.class);
    }
}

3- 总结

过滤器使用场景: 在请求进入控制层之前对请求作统一处理,避免大量重复书写代码,当然也可以对响应进行一定处理,从而使请求和响应都按照我们的意愿去执行.

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值