[JAVAee]Spring拦截器

适用场景

像是页面的登录验证处理,权限校验,登录日志的处理.

实现步骤

  1. 创建⾃定义拦截器,实现 HandlerInterceptor 接⼝的 preHandle(执⾏具体⽅法之前的预处理⽅法.
  2. 将⾃定义拦截器加⼊ WebMvcConfigurer 的 addInterceptors ⽅法中.

下面以登录验证为例,实现拦截器.

实现HandlerInterceptor接口,并重写preHandle方法(在业务处理器处理请求之前被调用)

java 复制代码
@Component
public class Interceptor implements HandlerInterceptor {
    //preHandle方法返回true表示能通过,并继续执行原本的下一步.
    //返回false表示不能通过,执行其他程序或返回.
    @Override
    public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) throws Exception {
        HttpSession session = request.getSession(false);
        if(session != null && session.getAttribute("user") != null){
            return true;//验证用户已为登录状态
        }
        //用户未登录
        response.sendRedirect("login.html");
        return false;
    }
}

实现WebMvcConfigurer接口,将上面实现的拦截器加入到其中

java 复制代码
@Configuration
public class MyConfig implements WebMvcConfigurer {
    @Autowired//注入拦截器的对象
    Interceptor Interceptor;

    @Override//添加拦截器
    public void addInterceptors(InterceptorRegistry registry) {
        registry.addInterceptor(Interceptor)//将拦截器加入
                .addPathPatterns("/**")//拦截所有的方法
                .excludePathPatterns("/**/*.html")//放开(不拦截)以.html结尾的文件
                .excludePathPatterns("/user/login");//放开url为user/login的方法
    }
}
相关推荐
雨中飘荡的记忆16 小时前
保证金系统入门到实战
java·后端
Nyarlathotep011316 小时前
Java内存模型
java
暮色妖娆丶21 小时前
不过是吃了几年互联网红利罢了,我高估了自己
java·后端·面试
NE_STOP21 小时前
MyBatis-参数处理与查询结果映射
java
狂奔小菜鸡1 天前
Day40 | Java中的ReadWriteLock读写锁
java·后端·java ee
SimonKing1 天前
JetBrains 用户狂喜!这个 AI 插件让 IDE 原地进化成「智能编码助手」
java·后端·程序员
狂奔小菜鸡1 天前
Day39 | Java中更灵活的锁ReentrantLock
java·后端·java ee
NE_STOP1 天前
MyBatis-配置文件解读及MyBatis为何不用编写Mapper接口的实现类
java