自定义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()方法