Spring 拦截器

什么是拦截器

一般指的是在浏览器页面向服务端发出请求后,拦截请求,对请求进行一系列的操作;或者在服务器返回数据时,在数据到达浏览器界面前,做一些操作,来完成功能的增强。

使用场景:解决请求的共性问题,如:乱码问题、权限验证问题等

实现

1. 编写拦截器类实现HandlerIntercepto接口

public class TestInterceptor implements HandlerInterceptor {
    public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) throws Exception {
        return false;
    }
    public void postHandle(HttpServletRequest request, HttpServletResponse response, Object handler, ModelAndView modelAndView) throws Exception {
    }
    public void afterCompletion(HttpServletRequest request, HttpServletResponse response, Object handler, Exception ex) throws Exception {
    }
}

2. 将拦截器注册进SpringMVC框架中

命名空间

xmlns:mvc="http://www.springframework.org/schema/mvc"
http://www.springframework.org/schema/mvc
http://www.springframework.org/schema/mvc/spring-mvc.xsd
<!--注册拦截器-->
<mvc:interceptors>
    <!--注册-->
    <bean class="com.imooc.test.interceptor.TestInterceptor"></bean>
</mvc:interceptors>

3. 配置拦截器的拦截规则

<!--注册拦截器-->
<mvc:interceptors>
  <mvc:interceptor>
    <!--匹配规则-->
    <mvc:mapping path="/viewAll.form"/>
    <!--注册-->
    <bean class="com.imooc.test.interceptor.TestInterceptor"></bean>
  </mvc:interceptor>
</mvc:interceptors>

其他实现方式

这里写图片描述

public class TestInterceptor2  implements WebRequestInterceptor {
    //没有返回值,不能终止请求
    public void preHandle(WebRequest webRequest) throws Exception {

    }
    public void postHandle(WebRequest webRequest, ModelMap modelMap) throws Exception {
    }
    public void afterCompletion(WebRequest webRequest, Exception e) throws Exception {
    }
}

三个方法

1. preHandler方法

在请求被处理之前调用。是否需要将当前的请求拦截下来,返回true请求继续运行,返回false请求终止(包括action层也会终止),Object arg代表被拦截的请求的目标对象。

这里写图片描述

2. postHandler方法

在请求被处理之后调用

这里写图片描述

3. afterCompletion方法

在请求处理结束后调用,用作资源销毁,方法不常用。

这里写图片描述

多拦截器协同工作流程

这里写图片描述

这里写图片描述

过滤器与拦截器

区别

  1. 拦截器是基于java的反射机制的,而过滤器是基于函数回调。
  2. 拦截器依赖于框架容器,过滤器依赖与Servlet容器。
  3. 拦截器只能对action请求起作用,而过滤器则可以对几乎所有的请求起作用。
  4. 拦截器可以访问action上下文、值栈里的对象,而过滤器不能访问。
  5. 在action的生命周期中,拦截器可以多次被调用,而过滤器只能在容器初始化时被调用一次。
  6. 拦截器可以获取IOC容器中的各个bean,而过滤器就不行,这点很重要,在拦截器里注入一个service,可以调用业务逻辑

Filter解决编码问题

这里写图片描述

拦截器解决编码、权限问题

这里写图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值