SpringMVC:拦截器(Interceptor)

1. 简介

拦截器(Interceptor)类似于过滤器(Filter)

Spring MVC的拦截器作用是在请求到达控制器之前或之后进行拦截,可以对请求和响应进行一些特定的处理。拦截器可以用于很多场景下:

  1. 登录验证:对于需要登录才能访问的网址,使用拦截器可以判断用户是否已登录,如果未登录则跳转到登录页面。

  2. 权限校验:根据用户权限对部分网址进行访问控制,拒绝未经授权的用户访问。

  3. 请求日志:记录请求信息,例如请求地址、请求参数、请求时间等,用于排查问题和性能优化。

  4. 更改响应:可以对响应的内容进行修改,例如添加头信息、调整响应内容格式等。

拦截器和过滤器的区别在于它们的作用层面不同。

* 过滤器更注重在请求和响应的流程中进行处理,可以修改请求和响应的内容,例如设置编码和字符集、请求头、状态码等。

* 拦截器则更加侧重于对控制器进行前置或后置处理,在请求到达控制器之前或之后进行特定的操作,例如打印日志、权限验证等。

2. 定义拦截器

实现HandlerInterceptor接口 选择性实现preHandle、postHandle、afterCompletion方法

* preHandle:处理器方法调用之前执行

只有该方法有返回值,返回值是布尔类型,true放行,false拦截。

* postHandle:处理器方法调用之后执行

* afterCompletion:渲染完成后执行

java 复制代码
public class Interceptor1 implements HandlerInterceptor {
    @Override
    public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) throws Exception {
        System.out.println("preHandle执行啦");
        return true;
    }

    @Override
    public void postHandle(HttpServletRequest request, HttpServletResponse response, Object handler, ModelAndView modelAndView) throws Exception {
        System.out.println("postHandle执行啦");
    }

    @Override
    public void afterCompletion(HttpServletRequest request, HttpServletResponse response, Object handler, Exception ex) throws Exception {
        System.out.println("afterCompletion执行啦");
    }
}

3. 配置拦截器

方式一: 要在springmvc.xml中导入对应的包进行扫描

XML 复制代码
    <!--配置拦截器,基本方式:基于xml文件配置
    注意:默认对所有请求进行拦截-->
    <mvc:interceptors>
        <!--第一种方式,导入全类名-->
        <bean class="com.itgyl.springmvc.interceptors.Interceptor1"></bean>
    </mvc:interceptors>

方式二:基于注解实现

XML 复制代码
    <!--配置拦截器,基本方式:基于xml文件配置
    注意:默认对所有请求进行拦截-->
    <mvc:interceptors>
        <!--第二种方式,基于注解自动装配-->
         <ref bean="interceptor1"></ref>
    </mvc:interceptors>
java 复制代码
@Component
public class Interceptor1 implements HandlerInterceptor {

4. 高级配置

XML 复制代码
     <!--拦截器高级配置-->
    <mvc:interceptors>
        <mvc:interceptor>
            <!--对所有路径进行过滤-->
            <mvc:mapping path="/**"/>
            <!--除了该路径不过滤-->
            <mvc:exclude-mapping path="/ok"/>
            <ref bean="interceptor1"></ref>
        </mvc:interceptor>
    </mvc:interceptors>
相关推荐
ST.J41 分钟前
swing笔记
java·笔记
菩提树下的凡夫1 小时前
瑞芯微RV1126目标识别算法Yolov8的部署应用
java·算法·yolo
尚学教辅学习资料1 小时前
Ruoyi-vue-plus-5.x第五篇Spring框架核心技术:5.1 Spring Boot自动配置
vue.js·spring boot·spring
爱隐身的官人1 小时前
新后端漏洞(上)- Java RMI Registry反序列化漏洞
java·反序列化漏洞
叫我阿柒啊1 小时前
从Java全栈到前端框架:一次真实的面试对话与技术解析
java·javascript·typescript·vue·springboot·react·前端开发
晚安里1 小时前
Spring 框架(IoC、AOP、Spring Boot) 的必会知识点汇总
java·spring boot·spring
爱隐身的官人1 小时前
新后端漏洞(上)- Aapache Tomcat AJP 文件包含漏洞(CVE-2020-1938)
java·tomcat·ajp
@CLoudbays_Martin112 小时前
为什么动态视频业务内容不可以被CDN静态缓存?
java·运维·服务器·javascript·网络·python·php
四谎真好看2 小时前
Java 学习笔记(进阶篇2)
java·笔记·学习
上官浩仁2 小时前
springboot ioc 控制反转入门与实战
java·spring boot·spring