SpringMVC札集(09)——拦截器


自定义View系列教程00–推翻自己和过往,重学自定义View
自定义View系列教程01–常用工具介绍
自定义View系列教程02–onMeasure源码详尽分析
自定义View系列教程03–onLayout源码详尽分析
自定义View系列教程04–Draw源码分析及其实践
自定义View系列教程05–示例分析
自定义View系列教程06–详解View的Touch事件处理
自定义View系列教程07–详解ViewGroup分发Touch事件
自定义View系列教程08–滑动冲突的产生及其处理


探索Android软键盘的疑难杂症
深入探讨Android异步精髓Handler
详解Android主流框架不可或缺的基石
站在源码的肩膀上全解Scroller工作机制


Android多分辨率适配框架(1)— 核心基础
Android多分辨率适配框架(2)— 原理剖析
Android多分辨率适配框架(3)— 使用指南


SpringMVC的处理器拦截器类似于Servlet开发中的过滤器Filter,用于对处理器进行预处理和后处理。在此,以示例的方式讲解拦截器的处理。


实现Interceptor

在该示例中我们定义两个拦截器,代码如下。

第一个拦截器:

/** 
* @author 原创作者:谷哥的小弟
* @blog   博客地址:http://blog.csdn.net/lfdfhl
* @time   创建时间:2017年8月1日 上午9:28:26 
* @info   描述信息:SpringMVC拦截器
*/
package cn.com.interceptor;

import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import org.springframework.web.servlet.HandlerInterceptor;
import org.springframework.web.servlet.ModelAndView;

public class Interceptor1 implements HandlerInterceptor{

    public boolean preHandle(HttpServletRequest arg0, HttpServletResponse arg1,Object arg2) throws Exception {
        System.out.println("第一个拦截器Interceptor的preHandle()方法");
        return true;
    }

    public void postHandle(HttpServletRequest arg0, HttpServletResponse arg1,Object arg2, ModelAndView arg3) throws Exception {
        System.out.println("第一个拦截器Interceptor的postHandle()方法");

    }

    public void afterCompletion(HttpServletRequest arg0,HttpServletResponse arg1, Object arg2, Exception arg3)throws Exception {
        System.out.println("第一个拦截器Interceptor的afterCompletion()方法");

    }

}

第二个拦截器:

/** 
* @author 原创作者:谷哥的小弟
* @blog   博客地址:http://blog.csdn.net/lfdfhl
* @time   创建时间:2017年8月1日 上午9:28:26 
* @info   描述信息:SpringMVC拦截器
*/
package cn.com.interceptor;

import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;

import org.springframework.web.servlet.HandlerInterceptor;
import org.springframework.web.servlet.ModelAndView;

public class Interceptor2 implements HandlerInterceptor{

    public boolean preHandle(HttpServletRequest arg0, HttpServletResponse arg1,Object arg2) throws Exception {
        System.out.println("第二个拦截器Interceptor的preHandle()方法");
        return true;
    }

    public void postHandle(HttpServletRequest arg0, HttpServletResponse arg1,Object arg2, ModelAndView arg3) throws Exception {
        System.out.println("第二个拦截器Interceptor的postHandle()方法");

    }

    public void afterCompletion(HttpServletRequest arg0,HttpServletResponse arg1, Object arg2, Exception arg3)throws Exception {
        System.out.println("第二个拦截器Interceptor的afterCompletion()方法");

    }

}
  • Interceptor需要实现HandlerInterceptor接口,并覆写里面的三个方法。

  • preHandle( ): 该方法将在处理器被调用前执行。SpringMVC 中的Interceptor 是链式的调用的,在一个应用中可同时存在多个Interceptor ;每个Interceptor的调用会依据其声明顺序依次执行,而且最先执行的都是Interceptor 中的preHandle( )方法,故可在该方法中进行一些前置初始化操作或预处理,也常在该方法中进行一些判断来决定请求是否要继续进行下去。该方法返回值为false 时,表示拦截请求即后续的Interceptor 和Controller 都不会再执行;当方法的返回值为true 时就会继续调用下一个Interceptor 的preHandle( );假若已经是最后一个Interceptor就会调用当前请求的Controller

  • postHandle( ): preHandle()的返回值为true 时才会被调用到该方法,这是一个前提条件。假若满足这个前提,那么该方法会在处理器被执行但在DispatcherServlet 进行视图返回渲染之前被调用;所以我们可以在这个方法中对ModelAndView进行相关操作。请注意:postHandle( )被调用的顺序跟preHandle( )是相反的,即先声明的Interceptor的postHandle( )反而会后执行

  • afterCompletion( ): preHandle()的返回值为true 时才会被调用到该方法,这是一个前提条件。顾名思义,该方法将在处理器被调用结束之后(即DispatcherServlet 渲染了对应的视图之后)执行。该方法的主要用于资源清理。


配置springmvc.xml

<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
    xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" 
    xmlns:mvc="http://www.springframework.org/schema/mvc"
    xmlns:context="http://www.springframework.org/schema/context"
    xmlns:aop="http://www.springframework.org/schema/aop" 
    xmlns:tx="http://www.springframework.org/schema/tx"
    xsi:schemaLocation="http://www.springframework.org/schema/beans 
        http://www.springframework.org/schema/beans/spring-beans-3.2.xsd 
        http://www.springframework.org/schema/mvc 
        http://www.springframework.org/schema/mvc/spring-mvc-3.2.xsd 
        http://www.springframework.org/schema/context 
        http://www.springframework.org/schema/context/spring-context-3.2.xsd 
        http://www.springframework.org/schema/aop 
        http://www.springframework.org/schema/aop/spring-aop-3.2.xsd 
        http://www.springframework.org/schema/tx 
        http://www.springframework.org/schema/tx/spring-tx-3.2.xsd">


    <!-- 配置自动扫描 -->
    <context:component-scan base-package="cn.com"></context:component-scan>

    <!-- 配置注解开发所需的处理器映射器-->
    <bean class="org.springframework.web.servlet.mvc.method.annotation.RequestMappingHandlerMapping"></bean>

    <!-- 配置注解开发所需的处理器适配器 -->
    <bean class="org.springframework.web.servlet.mvc.method.annotation.RequestMappingHandlerAdapter"></bean>


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

    <!--配置拦截器 -->
    <mvc:interceptors>
        <mvc:interceptor>
            <mvc:mapping path="/**"/>
            <bean class="cn.com.interceptor.Interceptor1"></bean>
        </mvc:interceptor>
        <mvc:interceptor>
            <mvc:mapping path="/**"/>
            <bean class="cn.com.interceptor.Interceptor2"></bean>
        </mvc:interceptor>
    </mvc:interceptors>


</beans>

在代码第36行至46行配置之前编写的两个拦截器。


编写Controller

/** 
* @author 原创作者:谷哥的小弟
* @blog   博客地址:http://blog.csdn.net/lfdfhl
* @time   创建时间:2017年8月1日 上午9:28:26 
* @info   描述信息:SpringMVC拦截器
*/
package cn.com.controller;
import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.RequestMapping;

@Controller
public class AnnotationController {

    @RequestMapping("hello")
    public String helloSpringMVCAnnotation(){
        return "test";
    }

}

在此实现一个非常简单的Controller

部署测试

部署该示例后,在浏览器中输入:
http://localhost:8081/SpringMVC08/hello.do

输出日志如下:

第一个拦截器Interceptor的preHandle()方法
第二个拦截器Interceptor的preHandle()方法
第二个拦截器Interceptor的postHandle()方法
第一个拦截器Interceptor的postHandle()方法
第二个拦截器Interceptor的afterCompletion()方法
第一个拦截器Interceptor的afterCompletion()方法

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

谷哥的小弟

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值