Spring框架之拦截器(1.0)

Spring框架之拦截器(1.0)

SpringMVC 中的Interceptor 拦截器也是相当重要和相当有用的,它的主要作用是拦截用户的请求并进行相应的处理。比如通过它来进行权限验证,或者是来判断用户是否登陆,或者是像12306 那样子判断当前时间是否是购票时间。
在这里插入图片描述
在这里插入图片描述

HandlerInterceptor 接口中定义了三个方法,我们就是通过这三个方法来对用户的请求进行拦截处理的。

(1 )preHandle (HttpServletRequest request, HttpServletResponse response, Object handle) 方法,顾名思义,该方法将在请求处理之前进行调用。SpringMVC 中的Interceptor 是链式的调用的,在一个应用中或者说是在一个请求中可以同时存在多个Interceptor 。每个Interceptor 的调用会依据它的声明顺序依次执行,而且最先执行的都是Interceptor 中的preHandle 方法,所以可以在这个方法中进行一些前置初始化操作或者是对当前请求的一个预处理,也可以在这个方法中进行一些判断来决定请求是否要继续进行下去。该方法的返回值是布尔值Boolean类型的,当它返回为false 时,表示请求结束,后续的Interceptor 和Controller 都不会再执行;当返回值为true 时就会继续调用下一个Interceptor 的preHandle 方法,如果已经是最后一个Interceptor 的时候就会是调用当前请求的Controller 方法。
(2 )postHandle (HttpServletRequest request, HttpServletResponse response, Object handle, ModelAndView modelAndView) 方法,由preHandle 方法的解释我们知道这个方法包括后面要说到的afterCompletion 方法都只能是在当前所属的Interceptor 的preHandle 方法的返回值为true 时才能被调用。postHandle 方法,顾名思义就是在当前请求进行处理之后,也就是Controller 方法调用之后执行,但是它会在DispatcherServlet 进行视图返回渲染之前被调用,所以我们可以在这个方法中对Controller 处理之后的ModelAndView 对象进行操作。postHandle 方法被调用的方向跟preHandle 是相反的,也就是说先声明的Interceptor 的postHandle 方法反而会后执行。
(3 )afterCompletion(HttpServletRequest request, HttpServletResponse response, Object handle, Exception ex) 方法,该方法也是需要当前对应的Interceptor 的preHandle 方法的返回值为true 时才会执行。顾名思义,该方法将在整个请求结束之后,也就是在DispatcherServlet 渲染了对应的视图之后执行。这个方法的主要作用是用于进行资源清理工作的

范例:实现一个简单的拦截器

1,新建一个MyInterceptor.java类

package cn.mldn.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 MyInterceptor implements HandlerInterceptor {

	@Override
	public boolean preHandle(HttpServletRequest request,
			HttpServletResponse response, Object handler) throws Exception {
		System.out.println("【*** preHandle】 cls = " + handler.getClass());
		return true ;	// 如果不返回true表示截停,不在执行后续的控制层操作
	}

	@Override
	public void postHandle(HttpServletRequest request,
			HttpServletResponse response, Object handler,
			ModelAndView modelAndView) throws Exception {
		System.out.println("【*** postHandle】 " + modelAndView);
	}

	@Override
	public void afterCompletion(HttpServletRequest request,
			HttpServletResponse response, Object handler, Exception ex)
			throws Exception {
		System.out.println("【*** afterCompletion】 cls = " + handler.getClass());
	}
}

2,配置拦截器

<?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:p="http://www.springframework.org/schema/p"
	xmlns:mvc="http://www.springframework.org/schema/mvc"
	xmlns:context="http://www.springframework.org/schema/context"
	xmlns:aop="http://www.springframework.org/schema/aop"
	xsi:schemaLocation="http://www.springframework.org/schema/aop http://www.springframework.org/schema/aop/spring-aop-4.1.xsd
		http://www.springframework.org/schema/mvc http://www.springframework.org/schema/mvc/spring-mvc-4.1.xsd
		http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans-4.1.xsd
		http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context-4.1.xsd">
	<!-- 配置项目之中使用Annotation注解操作 -->
	<context:annotation-config/>
	<context:component-scan base-package="cn.mldn"/>
	<!-- 配置Spring MVC的相关操作 -->
	<mvc:annotation-driven/>
	<!-- 表示配置默认的Servlet程序处理 -->
	<mvc:default-servlet-handler/>
	<mvc:interceptors>
		<mvc:interceptor>
			<!-- 针对于那个路径下的内容进行拦截,这个路径同资源文件的定位符 -->
			<mvc:mapping path="/pages/**/*.action"/>
			<bean class="cn.mldn.interceptor.MyInterceptor"/>
		</mvc:interceptor>
	</mvc:interceptors>
	<aop:aspectj-autoproxy/> 
</beans>

3,emp_add.jsp

  <body>
  	<form action="<%=basePath%>pages/back/emp/empAdd.action" method="post">
  		雇员姓名:<input type="text" name="ename" id="ename" value="SMITH"><br>
  		部门名称:<input type="text" name="dept.dname" id="dept.dname" value="财务部"><br>
  		<input type="submit" value="提交">
  		<input type="reset" value="重置">
  	</form> 
  </body>

4,empAdd.action

package cn.mldn.action;
import java.io.File;
import java.util.Locale;
import java.util.UUID;
import org.springframework.stereotype.Controller;
import org.springframework.web.servlet.ModelAndView;
import cn.mldn.vo.Emp;
@Controller
@RequestMapping("/pages/back/emp/*")
// 此处描述的是定义父路径
public class EmpAction { // 完全是一个独立的类
	@RequestMapping(value = "empAdd")
	public ModelAndView add(Emp emp) { // 此处表示接收的参数就是Emp类型
		System.out.println(emp);
		ModelAndView mav = new ModelAndView();
		mav.setViewName("forward"); // 设置跳转路径
		mav.addObject("msg", "天要下雨啦,收衣服啦!");
		mav.addObject("myemp", emp);
		return mav;
	}
}

在这里插入图片描述
而后发现,拦截器处理前后都有一个org.springframework.web.method.HandlerMethod类对象返回。
观察此类:

public ObjectgetBean( )        :返回触发此拦截器的程序类(XxxAction);
public Method  getMethod( )    :取得出发此拦截器的方法名称;
public Class<?> getBeanType( ) :取得触发此拦截器程序类的Class对象;
public Methodparameter[] getMethodparameter( ) :取得所有提交到此方法上的参数;

所有用户请求时提交的参数,在拦截器里面都使用“org.springframework.core.MethodParameter"程序类进行接收,所以来观察这个类中给出的方法:

public Method getMethod( )          :取得调用的方法对象;
public String getParameterName( )   :取得提交到此Action上的参数名称
public Class<?> getParameterType( ) : 取得此参数的类型;
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值