springMVC拦截器

1拦截器概述

1.1什么是拦截器?

springMVC中的拦截器(Interceptor)类似于servlet中的过滤器(Filter),它主要用于拦截用户请求并作相应的处理。例如通过拦截器可以进行权限验证、记录请求信息的日志、判断用户是否登录等。

要使用springMVC中的拦截器,就需要对拦截器类进行定义和配置。通常拦截器类可以通过两种方式 来定义。

1通过实现HandlerInterceptor接口,或继承HandlerInterceptor接口的实现类来定义.

2通过实现WebRequestInterceptor接口,或继承WebRequestInterceptor接口的实现类来定义。

以实现HandlerInterceptor接口方式为例,自定义拦截器类的代码如下:

public class CustomInterceptor 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 {
}

}

上述代码中,自定义拦截器实现了HandlerInterceptor接口,并实现了接口中的三个方法:

preHandle()方法:该方法会在控制器方法前执行,其返回值表示是否中断后续操作。当其返回值为true时,表示继续向下执行;当其返回值为false时,会中断后续的所有操作(包括调用下一个拦截器和控制器类中的方法执行等)。

postHandle()方法:该方法会在控制器方法调用之后,且解析视图之前执行。可以通过此方法对模型和视图作出进一步的修改。

afterCompletion()方法:该方法会在整个请求完成,即视图渲染结束之后执行,可以通过此方法实现一些资源清理、记录日志信息等工作。

1.2拦截器的配置

开发拦截器就像开发servlet或者filter一样,都需要在配置文件中进行配置,配置代码如下:

mvc:interceptors

mvc:interceptor

<mvc:mapping path="/**"/>
<mvc:exclude-mapping path=""/>


</mvc:interceptor>

mvc:interceptor
<mvc:mapping path="/hello"/>

</mvc:interceptor>

上面的代码中,mvc:interceptors元素用于配置一组拦截器,其子元素中定义的是全局拦截器,它会拦截所有的请求;而mvc:interceptor元素中定义的是指定路径的拦截器,它会对指定路径下的请求生效。mvc:interceptor元素的子元素mvc:mapping用于配置拦截器作用的路径,该路径在其属性path中定义。如上述代码中path的属性值/**表示拦截所有路径,“/hello”表示拦截所有以“/hello”结尾的路径。如果在请求路径中包含不需要拦截的内容,还可以通过mvc:exclude-mapping元素进行配置。

注意:mvc:interceptor中的子元素必须按照上述代码中的配置顺序边写,即mvc:mappingmvc:exclude-mapping,否则文件会报错。

2.拦截器的执行流程

2.1单个拦截器的执行流程

在运行程序时,拦截器的执行是有一定顺序的,该顺序与配置文件中所定义的拦截器的顺序相关。

每个拦截器,在程序中的执行流程如下图所示:

1.程序先执行preHandle()方法,如果该方法的返回值为true,则程序会继续向下执行处理器中的方法,否则将不再向下执行。

2.在业务处理器(即控制器Controller类)处理完请求后,会执行postHandle()方法,然后会通过DispatcherServlet向客户端返回响应。

3.在DispatcherServlet处理完请求后,才会执行afterCompletion()方法。

测试案例:

通过一个测试程序来验证它的执行流程。

新建一个web项目,准备好springmvc程序运行所需要的jar包,在web.xml中配置前端过滤器和初始化加载信息。

新建一个测试controller,代码如下:

/**

  • @author mz

  • @version V1.0

  • @Description: 拦截器测试
    */
    @Controller
    public class HelloController {

    @RequestMapping("/hello")
    public String Hello() {
    System.out.println(“Hello!”);
    return “success”;
    }
    }
    然后新建一个拦截器,实现HandlerInterceptor接口,并实现其中的方法。

/**

  • @author mz

  • @version V1.0

  • @Description: 实现了HandlerInterceptor接口的自定义拦截器类
    */
    public class CustomeInterceptor implements HandlerInterceptor {
    @Override
    public boolean preHandle(HttpServletRequest httpServletRequest, HttpServletResponse httpServletResponse, Object o)
    throws Exception {
    System.out.println(“CustomInterceptor…preHandle”);
    //对浏览器的请求进行放行处理
    return true;
    }

    @Override
    public void postHandle(HttpServletRequest httpServletRequest, HttpServletResponse httpServletResponse, Object o, ModelAndView modelAndView)
    throws Exception {
    System.out.println(“CustomInterceptor…postHandle”);
    }

    @Override
    public void afterCompletion(HttpServletRequest httpServletRequest, HttpServletResponse httpServletResponse, Object o, Exception e)
    throws Exception {
    System.out.println(“CustomInterceptor…afterCompletion”);
    }
    }
    在配置文件中配置拦截器

<!--定义组件扫描器,指定需要扫描的包-->
<context:component-scan base-package="com.ma.controller"/>

<!-- 配置视图解析器 -->
<bean class="org.springframework.web.servlet.view.InternalResourceViewResolver">
    <property name="prefix" value="/WEB-INF/jsp/"/>
    <property name="suffix" value=".jsp"/>
</bean>

<!--配置拦截器-->
<mvc:interceptors>
    <bean class="com.ma.interceptor.CustomeInterceptor" />  
</beans>

把项目发布到Tomcat中,运行测试:

2.2多个拦截器的执行流程

多个拦截器(假设有两个拦截器interceptor1和interceptor2,并且在配置文件中,interceptor1拦截器配置在前),在程序中的执行流程如下入所示:

从图可以看出,当有多个拦截器同时工作时,他们的preHandle()方法会按照配置文件中拦截器的顺讯执行,而他们的postHandle()方法和afterCompletion()方法则会按照配置顺序中的反序执行。

测试案例:

新建两个拦截器:

/**

  • @author mz

  • @version V1.0

  • @Description: 第一个拦截器
    */
    public class Intercptor1 implements HandlerInterceptor {
    @Override
    public boolean preHandle(HttpServletRequest httpServletRequest,
    HttpServletResponse httpServletResponse, Object o) throws Exception {
    System.out.println(“Interceptor1…preHandle”);
    return true;
    }

    @Override
    public void postHandle(HttpServletRequest httpServletRequest, HttpServletResponse httpServletResponse, Object o, ModelAndView modelAndView) throws Exception {
    System.out.println(“Interceptor1…postHandle”);
    }

    @Override
    public void afterCompletion(HttpServletRequest httpServletRequest, HttpServletResponse httpServletResponse, Object o, Exception e) throws Exception {
    System.out.println(“Interceptor1…afterCompletion”);
    }
    /**

  • @author mz

  • @version V1.0

  • @Description: 第二个拦截器
    */
    public class Interceptor2 implements HandlerInterceptor {
    @Override
    public boolean preHandle(HttpServletRequest httpServletRequest, HttpServletResponse httpServletResponse, Object o) throws Exception {
    System.out.println(“Interceptor2…preHandle”);
    return true;
    }

    @Override
    public void postHandle(HttpServletRequest httpServletRequest, HttpServletResponse httpServletResponse, Object o, ModelAndView modelAndView) throws Exception {
    System.out.println(“Interceptor2…postHandle”);
    }

    @Override
    public void afterCompletion(HttpServletRequest httpServletRequest, HttpServletResponse httpServletResponse, Object o, Exception e) throws Exception {
    System.out.println(“Interceptor2…afterCompletion”);
    }
    }
    配置信息:

    <mvc:interceptor>
        <!--配置拦截器的作用路径-->
        <mvc:mapping path="/**"/>
        <!--定义在<mvc:interceptor>下面的表示匹配指定路径的请求才进行拦截-->
        <bean class="com.ma.interceptor.Intercptor1"/>
    </mvc:interceptor>
    <!--拦截器2-->
    <mvc:interceptor>
        <mvc:mapping path="/hello"/>
        <bean class="com.ma.interceptor.Interceptor2"/>
    </mvc:interceptor>
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值