Springmvc拦截器

基本概述

拦截器Interceptor
拦截器类似于JavaWeb部分学过Filter过滤器,在请求到达目标方法之前,对请求拦截,可以进行身份验证、日志等
拦截器与Filter的区别
https://blog.youkuaiyun.com/zxd1435513775/article/details/80556034
如何实现一个拦截器
  1.自定义类实现 HandlerInterceptor接口的方法

public class LoginInterceptor implements HandlerInterceptor{
	@Override
	public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler)
			throws Exception {
	}
	@Override
	public void postHandle(HttpServletRequest request, HttpServletResponse response, Object handler,
			ModelAndView modelAndView) throws Exception {
	}
	@Override
	public void afterCompletion(HttpServletRequest request, HttpServletResponse response, Object handler, Exception ex)
			throws Exception {
	}
}

preHandle():该方法在目标方法之前被调用, 若返回值为true,则继续调用后续的拦截器和目标方法,若返回值为false,则不会再调用后续的拦截器和目标方法可以考虑做权限,日志或者事务等
postHandle():调用目标方法之后,但渲染视图之前被调用 可以对请求域中的属性或者视图做出修改!
afterCompletion():渲染视图之后被调用, 可以在该方法中进行一些释放资源的操作

     2.在springmvc配置文件中配置相对应的拦截器(分为拦截所有请求和自定义拦截路径)

1、拦截所有请求

<mvc:interceptors>
	<!--配置自定义拦截器 ,所有的路径都拦截 -->
	<bean class="com.xz.interceptor.LoginInterceptor"></bean>
</mvc:interceptors>

2、自定义拦截请求(配置路径时不要带项目名,在服务器端解析)

<mvc:interceptors>
	<mvc:interceptor>
		<!--在服务器进行解析,不能加上项目名-->
		<!--拦截指定路径或请求-->
		<mvc:mapping path="/user/**"/>
		<mvc:mapping path="/admin/**"/>
		<!--不拦截指定路径或请求-->
		<mvc:exclude-mapping path="/user"/>
		<mvc:exclude-mapping path="/userlogin"/>
		<mvc:exclude-mapping path="/admin/login"/>
		<mvc:exclude-mapping path="/admin/user/login"/>
		<!--指定拦截器-->
		<bean class="com.xz.interceptor.LoginInterceptor"></bean>
	</mvc:interceptor>
</mvc:interceptors>

SpringMVC 拦截器不拦截静态资源的三种处理方式:https://blog.youkuaiyun.com/qq_37677519/article/details/78164227

登录拦截器案例的实现

1、自定义类实现 HandlerInterceptor接口

public class LoginInterceptor implements HandlerInterceptor{

	@Override
	public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler)
			throws Exception {
		//在拦截点执行拦截,如果返回true则不执行拦截点后的操作(拦截成功)
		//返回false则不进行拦截
		HttpSession session = request.getSession();
		if(session.getAttribute("USER_NAME")!=null) {
			// 登录成功不拦截
			return true;
		}else {
			// 拦截后进入登录页面
			response.sendRedirect(request.getContextPath()+"/user");
			return false;
		}
	}
	@Override
	public void postHandle(HttpServletRequest request, HttpServletResponse response, Object handler,
			ModelAndView modelAndView) throws Exception {
		//在处理过程中进行拦截	
	}
	@Override
	public void afterCompletion(HttpServletRequest request, HttpServletResponse response, Object handler, Exception ex)
			throws Exception {
		//执行完毕,返回前拦截
	}
}

2.在springmvc配置文件中配置相对应的拦截器

<!--自定义拦截器-->
<mvc:interceptors>
	<mvc:interceptor>
		<!--在服务器进行解析,不能加上项目名-->
		<!--拦截指定路径或请求-->
		<mvc:mapping path="/user/**"/>
		<mvc:mapping path="/admin/**"/>
		<!--不拦截指定路径或请求-->
		<mvc:exclude-mapping path="/user"/>
		<mvc:exclude-mapping path="/userlogin"/>
		<mvc:exclude-mapping path="/admin/login"/>
		<mvc:exclude-mapping path="/admin/user/login"/>
		<!--指定拦截器-->
		<bean class="com.xz.interceptor.LoginInterceptor"></bean>
	</mvc:interceptor>
</mvc:interceptors>

多拦截器的执行顺序

多拦截器情况下,拦截器的执行顺序是由配置在springmvc.xml文件中的拦截器的顺序决定

<mvc:interceptors>
	<mvc:interceptor>
		<mvc:mapping path="/user/**"/>
		<bean class="com.xz.interceptor.LoginInterceptor1"></bean>
	</mvc:interceptor>
	<mvc:interceptor>
		<mvc:mapping path="/admin/**"/>
		<bean class="com.xz.interceptor.LoginInterceptor2"></bean>
	</mvc:interceptor>
</mvc:interceptors>

在这里插入图片描述
源码解析

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值