SpringMVC拦截器

简介: SpringMVC拦截器

SpringMVC拦截器



Spring MVC 的 拦截器 类似于Servlet 开发中的过滤器Filter,用于对处理器进行 预处理 和 后处理 。
将拦截器按一定的顺序联结成一条链,这条链称为 拦截器链(Interceptor Chain) 。在访问被拦截的方
法或字段时,拦截器链中的拦截器就会按其之前定义的顺序被调用。拦截器也是AOP思想的具体实现。


1.1 拦截器(interceptor)的作用


1.2 拦截器和过滤器区别


区别 过滤器(Filter) 拦截器(Interceptor)


使用范围 是Java Web servlet 规范中的一部分,任何工程都可以使用 是SpringMVC SpringMVC 框架的工程才能用框架自己的,只有使用了


拦截范围 在可以对所有要访问的资源拦截url-pattern 中配置了/*之后,


在<mvc:mappingpath=“”/>中配置了/**之
后,也可以多所有资源进行拦截,但 是可以 通
过<mvc:exclude-mapping path=“”/>标签
排除不需要拦截的资源


1.3 拦截器是快速入门


自定义拦截器很简单,只有如下三步:

① 创建拦截器类实现HandlerInterceptor接口
② 配置拦截器
③ 测试拦截器的拦截效果


① 创建拦截器类实现HandlerInterceptor接口
public class MyHandlerInterceptor1 implements HandlerInterceptor {
public boolean preHandle(HttpServletRequest request, HttpServletResponse
response, Object handler) {
System. out .println( "preHandle running..." );
return true ;
}
public void postHandle(HttpServletRequest request, HttpServletResponse
response, Object handler, ModelAndView modelAndView) {
System. out .println( "postHandle running..." );
}
public void afterCompletion(HttpServletRequest request, HttpServletResponse
response, Object handler, Exception ex) {
System. out .println( "afterCompletion running..." );
}
}

② 配置拦截器

< mvc:interceptors >
< mvc:interceptor >
< mvc:mapping path="/**" />
< bean class="com.itheima.interceptor.MyHandlerInterceptor1" />
</ mvc:interceptor >
</ mvc:interceptors >


③ 测试拦截器的拦截效果(编写目标方法)

@RequestMapping( "/quick23" )
@ResponseBody
public ModelAndView quickMethod23() throws IOException, ParseException {
System. out .println( " 目标方法执行 ...." );
ModelAndView modelAndView = new ModelAndView();
modelAndView.addObject( "name" , "itcast" );
modelAndView.setViewName( "index" );
return modelAndView;
}


③ 测试拦截器的拦截效果(访问网址)

http://localhost:8080/itheima_springmvc1/quick


控制台打印结果


1.4 多拦截器操作


同上,在编写一个MyHandlerInterceptor2操作,测试执行顺序


方法名 说明


preHandle()


方法将在请求处理之前进行调用,该 方法的 返回值 是布尔 值Boolean类型的 ,

当它返回为false 时,表示请求结束,后续的Interceptor 和Controller 都不会

再执行;当返回值为true 时就会继续调用下一个Interceptor 的preHandle 方


postHandle()

该方法是在当前请求进行处理之后被 调用, 前提是preHandle 方法的返回值为

true 时才能被调用,且它会在DispatcherServlet 进行视图返回渲染之前被调

用,所以我们可以在这个方法中对Controller 处理之后的ModelAndView 对象

进行操作

afterCompletion() 该方法将在整个请求结束之后,也就 是在之后执行,前提是preHandle 方法的返回值为DispatcherServ lettrue 时才能被调用渲染了对应的视图


1.5 拦截器方法说明


1.6 知识要点


自定义拦截器步骤

① 创建拦截器类实现HandlerInterceptor接口
② 配置拦截器
③ 测试拦截器的拦截效果


1.7 案例-用户登录权限控制


需求:用户没有登录的情况下,不能对后台菜单进行访问操作,点击菜单跳转到登录页面,只有用户登录

成功后才能进行后台功能的操作

相关文章
|
前端开发 Java Spring
56SpringMVC - 拦截器
56SpringMVC - 拦截器
41 0
|
6月前
|
XML Java 数据格式
|
6月前
|
JSON 算法 Java
SpringMVC(五)【拦截器】
SpringMVC(五)【拦截器】
|
7月前
|
数据采集 监控 前端开发
SpringMVC 拦截器
SpringMVC 拦截器
60 0
|
7月前
|
数据安全/隐私保护
SpringMVC拦截器
SpringMVC拦截器
64 0
|
7月前
springMVC之拦截器
springMVC之拦截器
|
Java
SpringMVC-拦截器
SpringMVC-拦截器
62 0
SpringMVC-拦截器
|
前端开发 JavaScript Java
SpringMVC 中的拦截器
SpringMVC 中的拦截器
|
XML 数据格式 容器
springmvc之拦截器
springmvc之拦截器
114 2