SpringMVC-interceptor

通过ReqeustMapping映射的网址,都会被某个Handler处理。
自定义栏拦截器需要实现HandlerInterceptor
默认情况下,对所有的RequestMappingd定义的网址都进行拦截。
-preHandle(),若返回true则,对request进行处理后,交给下一个拦截器或者业务Handler-可用来实现权限,事务,日志。
若返回false,相当于直接拦截掉了,不会再继续执行,不会执行post和afterCompletion以及后续的拦截器。
-postHandle(),业务处理器处理完后,DispatcherServlet向客户端返回响应前被调用。
-afterCompletion:DispatcherServlet向客户端返回响应后被调用,通常用来释放资源。

<servlet-name>-servlet.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:context="http://www.springframework.org/schema/context"
	xmlns:mvc="http://www.springframework.org/schema/mvc"
	xsi:schemaLocation="http://www.springframework.org/schema/mvc http://www.springframework.org/schema/mvc/spring-mvc-4.2.xsd
		http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans.xsd
		http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context-4.2.xsd">

	<context:component-scan base-package="spring"></context:component-scan>
	<bean class="org.springframework.web.servlet.view.InternalResourceViewResolver">
		<property name="prefix" value="/WEB-INF/views/"></property>
		<property name="suffix" value=".jsp"></property>
	</bean>

	<mvc:interceptors>
		<bean class="spring.HelloInterceptor"></bean>
	</mvc:interceptors>
	
	<mvc:default-servlet-handler/>
	<mvc:annotation-driven></mvc:annotation-driven>
</beans>
HelloInterceptor.java定义
package spring;

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

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

public class HelloInterceptor implements HandlerInterceptor{

	@Override
	public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler)
			throws Exception {
		System.out.println("preHandle");
		return true;
	}

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

	@Override
	public void afterCompletion(HttpServletRequest request, HttpServletResponse response, Object handler, Exception ex)
			throws Exception {
		System.out.println("afterCompletion");
	}
}
MyController.java定义
@Controller
public class TestJSONController {
	@RequestMapping("/testInterceptor")
	public String testInterceptor(){
		System.out.println("Business Mapping Handler");
		return "success";
	}
}

执行后输出的log为:
preHandle
Business Mapping Handler
postHandle
afterCompletion

指定拦截对象
指定拦截对象,可以通过如下配置设定。 注意<mvc:mapping>的定义必须在<bean>的上面,否则会报错。
<mvc:interceptors>		
	<mvc:interceptor>
		<mvc:mapping path="/testInterceptor"/>
		<bean class="spring.HelloInterceptor2"></bean>
	</mvc:interceptor>
</mvc:interceptors>
指定非拦截对象
指定不拦截的url,只需要通过如下方法即可。 注意必须先定义<mvc:mapping>然后再定义exclude-mapping,最后定义Bean,否则会报错。
<mvc:interceptors>		
	<mvc:interceptor>
		<mvc:mapping path="/test"/>
		<mvc:exclude-mapping path="/testInterceptor"/>
		<bean class="spring.HelloInterceptor"></bean>
	</mvc:interceptor>
</mvc:interceptors>
拦截器执行的顺序
如下所示的拦截器配置,有两个拦截器HelloInterceptor,HelloInterceptor2这两个拦截器都对URL /interceptor2起作用。
他们的执行顺序是preHandle1,preHandle2,posthandle2,posthandle1,afterCompletion2, afterCompletion1。类似于多个Filter的执行顺序。
若第二个拦截器中preHandle2返回false,由于preHandle1执行过了,所以会执行afterCompletoin1,而不会执行第二个拦截器的后续方法以及第一个拦截器的post方法。
<mvc:interceptors>
	<bean class="spring.HelloInterceptor"></bean>
	<mvc:interceptor>
		<mvc:mapping path="/interceptor2"/>
		<bean class="spring.HelloInterceptor2"></bean>
	</mvc:interceptor>
</mvc:interceptors>

<完>

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值