首页 > 编程知识 正文

spring拦截器配置,okhttp拦截器

时间:2023-05-06 08:20:52 阅读:149668 作者:353

SpringMVC的拦截器也相当重要,相当有用,主要作用是屏蔽用户的请求,进行适当的处理。 用它来验证权限,判断用户是否登录,像12306一样判断当前时间是否是购票时间。

一.定义拦截器实现类

SpringMVC拦截拦截拦截器的请求通过handler拦截器实现。 在SpringMVC中定义迭代器非常简单,主要有两种方法。 第一种方法是定义的Interceptor类是实现spring HandlerInterceptor接口的类,或者该类继承实现handler interceptor接口的类。 例如,在SpringMVC中,第二种方法是继承实现Spring的WebRequestInterceptor接口或实现WebRequestInterceptor的类。

(一)实现handler解释器界面

HandlerInterceptor界面定义了三种方法,我们用这三种方法拦截处理用户的请求。

)1) pre handle (httpservletrequestrequest,HttpServletResponse response,Object handle )方法,mldqz,在请求处理之前调用此方法SpringMVC的解释器被链式调用,可以在一个APP应用程序中或在一个请求中同时存在多个解释器。 每个Interceptor的调用按声明顺序依次执行,最初执行的是Interceptor内的preHandle方法,因此该方法可以进行预初始化操作,可以对当前请求进行预处理,也可以使用该方法判断是否继续请求此方法的返回值为布尔值Boolean类型,如果返回false,则表示请求结束,不再执行后续的Interceptor和Controller。 如果返回值为true,则继续调用以下Interceptor pre handle方法;如果已经是最后一个interceptor,则调用当前请求的Controller方法。

)2) posthandle (httpservletrequestrequest,HttpServletResponse response,Object handle,ModelAndView modelAndView )方法, 从preHandle方法的说明中可以看到,此方法还包括后面介绍的afterCompletion方法,只有在当前所属的interceptor pre handle方法的返回值为true时才会调用。 postHandle方法、mldqz在处理当前请求后执行,即在调用Controller方法后执行,但在返回并渲染视图之前调用DispatcherServlet,因此此方法使用CCD postHandle方法在与preHandle相反的方向上调用。 这意味着,之前声明的interceptor posthandle方法将在以后执行。 这与struts2interceptor的运行过程的类型略有不同。 Struts2中的拦截器执行过程也是链式的。 但是,在Struts2中,手动调用ActionInvocation的invoke方法以启动对下一个Interceptor或Action的调用,并且每个Interceptor在调用invoke方法之前的内容

)3) after completion (httpservletrequestrequest,HttpServletResponse response,Object handle,Exception ex )方法也是当前对应的intp 此方法在整个请求结束后执行,即dispatcher servlet渲染相应的视图后执行。 该方法的主要作用是用于资源整理工作。

简单的代码说明如下所示。

import javax.servlet.http.http servlet request; import javax.servlet.http.http无servlet轮询; importorg.spring framework.web.servlet.handler interceptor; importorg.spring framework.web.servlet.modelandview; publicclassspringmvcinterceptorimplementshandlerinterceptor {/* * * pre handle方法用于侦听处理器,使用ml

dqz,该方法将在Controller处理之前进行调用,SpringMVC中的Interceptor拦截器是链式的,可以同时存在

* 多个Interceptor,然后SpringMVC会根据声明的前后顺序一个接一个的执行,而且所有的Interceptor中的preHandle方法都会在

* Controller方法调用之前调用。SpringMVC的这种Interceptor链式结构也是可以进行中断的,这种中断方式是令preHandle的返

* 回值为false,当preHandle的返回值为false的时候整个请求就结束了。*/@Overridepublic booleanpreHandle(HttpServletRequest request,

HttpServletResponse response, Object handler)throwsException {//TODO Auto-generated method stub

return false;

}/*** 这个方法只会在当前这个Interceptor的preHandle方法返回值为true的时候才会执行。postHandle是进行处理器拦截用的,它的执行时间是在处理器进行处理之

* 后,也就是在Controller的方法调用之后执行,但是它会在DispatcherServlet进行视图的渲染之前执行,也就是说在这个方法中你可以对ModelAndView进行操

* 作。这个方法的链式结构跟正常访问的方向是相反的,也就是说先声明的Interceptor拦截器该方法反而会后调用,这跟Struts2里面的拦截器的执行过程有点像,

* 只是Struts2里面的intercept方法中要手动的调用ActionInvocation的invoke方法,Struts2中调用ActionInvocation的invoke方法就是调用下一个Interceptor

* 或者是调用action,然后要在Interceptor之前调用的内容都写在调用invoke之前,要在Interceptor之后调用的内容都写在调用invoke方法之后。*/@Overridepublic voidpostHandle(HttpServletRequest request,

HttpServletResponse response, Object handler,

ModelAndView modelAndView)throwsException {//TODO Auto-generated method stub

}/*** 该方法也是需要当前对应的Interceptor的preHandle方法的返回值为true时才会执行。该方法将在整个请求完成之后,也就是DispatcherServlet渲染了视图执行,

* 这个方法的主要作用是用于清理资源的,当然这个方法也只能在当前这个Interceptor的preHandle方法的返回值为true时才会执行。*/@Overridepublic voidafterCompletion(HttpServletRequest request,

HttpServletResponse response, Object handler, Exception ex)throwsException {//TODO Auto-generated method stub

}

}

(二)实现WebRequestInterceptor 接口

WebRequestInterceptor 中也定义了三个方法,我们也是通过这三个方法来实现拦截的。这三个方法都传递了同一个参数WebRequest ,那么这个WebRequest 是什么呢?这个WebRequest 是Spring 定义的一个接口,它里面的方法定义都基本跟HttpServletRequest 一样,在WebRequestInterceptor 中对WebRequest 进行的所有操作都将同步到HttpServletRequest 中,然后在当前请求中一直传递。

(1 )preHandle(WebRequest request) 方法。该方法将在请求处理之前进行调用,也就是说会在Controller 方法调用之前被调用。这个方法跟HandlerInterceptor 中的preHandle 是不同的,主要区别在于该方法的返回值是void ,也就是没有返回值,所以我们一般主要用它来进行资源的准备工作,比如我们在使用Hibernate 的时候可以在这个方法中准备一个Hibernate 的Session 对象,然后利用WebRequest 的setAttribute(name, value, scope)把它放到WebRequest 的属性中。这里可以说说这个setAttribute 方法的第三个参数scope ,该参数是一个Integer类型的。在WebRequest 的父层接口RequestAttributes 中对它定义了三个常量:

SCOPE_REQUEST :它的值是0 ,代表只有在request 中可以访问。

SCOPE_SESSION :它的值是1 ,如果环境允许的话它代表的是一个局部的隔离的session,否则就代表普通的session,并且在该session范围内可以访问。

SCOPE_GLOBAL_SESSION :它的值是2 ,如果环境允许的话,它代表的是一个全局共享的session,否则就代表普通的session,并且在该session 范围内可以访问。

(2 )postHandle(WebRequest request, ModelMap model) 方法。该方法将在请求处理之后,也就是在Controller 方法调用之后被调用,但是会在视图返回被渲染之前被调用,所以可以在这个方法里面通过改变数据模型ModelMap 来改变数据的展示。该方法有两个参数,WebRequest 对象是用于传递整个请求数据的,比如在preHandle 中准备的数据都可以通过WebRequest 来传递和访问;ModelMap 就是Controller 处理之后返回的Model 对象,我们可以通过改变它的属性来改变返回的Model 模型。

(3 )afterCompletion(WebRequest request, Exception ex) 方法。该方法会在整个请求处理完成,也就是在视图返回并被渲染之后执行。所以在该方法中可以进行资源的释放操作。而WebRequest 参数就可以把我们在preHandle 中准备的资源传递到这里进行释放。Exception 参数表示的是当前请求的异常对象,如果在Controller 中抛出的异常已经被Spring 的异常处理器给处理了的话,那么这个异常对象就是是null 。

下面是一个简单的代码说明:

importorg.springframework.ui.ModelMap;importorg.springframework.web.context.request.WebRequest;importorg.springframework.web.context.request.WebRequestInterceptor;public class AllInterceptor implementsWebRequestInterceptor {/*** 在请求处理之前执行,该方法主要是用于准备资源数据的,然后可以把它们当做请求属性放到WebRequest中*/@Overridepublic void preHandle(WebRequest request) throwsException {//TODO Auto-generated method stub

System.out.println("AllInterceptor...............................");

request.setAttribute("request", "request", WebRequest.SCOPE_REQUEST);//这个是放到request范围内的,所以只能在当前请求中的request中获取到

request.setAttribute("session", "session", WebRequest.SCOPE_SESSION);//这个是放到session范围内的,如果环境允许的话它只能在局部的隔离的会话中访问,否则就是在普通的当前会话中可以访问

request.setAttribute("globalSession", "globalSession", WebRequest.SCOPE_GLOBAL_SESSION);//如果环境允许的话,它能在全局共享的会话中访问,否则就是在普通的当前会话中访问

}/*** 该方法将在Controller执行之后,返回视图之前执行,ModelMap表示请求Controller处理之后返回的Model对象,所以可以在

* 这个方法中修改ModelMap的属性,从而达到改变返回的模型的效果。*/@Overridepublic void postHandle(WebRequest request, ModelMap map) throwsException {//TODO Auto-generated method stub

for(String key:map.keySet())

System.out.println(key+ "-------------------------");;

map.put("name3", "value3");

map.put("name1", "name1");

}/*** 该方法将在整个请求完成之后,也就是说在视图渲染之后进行调用,主要用于进行一些资源的释放*/@Overridepublic voidafterCompletion(WebRequest request, Exception exception)throwsException {//TODO Auto-generated method stub

System.out.println(exception + "-=-=--=--=-=-=-=-=-=-=-=-==-=--=-=-=-=");

}

}

二、把定义的拦截器类加到SpringMVC的拦截体系中

1.在SpringMVC的配置文件中加上支持MVC的schema

下面是我的声明示例

http://www.springframework.org/schema/beans/spring-beans-3.0.xsd

http://www.springframework.org/schema/context

http://www.springframework.org/schema/context/spring-context-3.0.xsd

http://www.springframework.org/schema/mvc

http://www.springframework.org/schema/mvc/spring-mvc-3.0.xsd">

这样在SpringMVC的配置文件中就可以使用mvc标签了,mvc标签中有一个mvc:interceptors是用于声明SpringMVC的拦截器的。

(二)使用mvc:interceptors标签来声明需要加入到SpringMVC拦截器链中的拦截器

由上面的示例可以看出可以利用mvc:interceptors标签声明一系列的拦截器,然后它们就可以形成一个拦截器链,拦截器的执行顺序是按声明的先后顺序执行的,先声明的拦截器中的preHandle方法会先执行,然而它的postHandle方法和afterCompletion方法却会后执行。

在mvc:interceptors标签下声明interceptor主要有两种方式:

(1)直接定义一个Interceptor实现类的bean对象。使用这种方式声明的Interceptor拦截器将会对所有的请求进行拦截。

(2)使用mvc:interceptor标签进行声明。使用这种方式进行声明的Interceptor可以通过mvc:mapping子标签来定义需要进行拦截的请求路径。

经过上述两步之后,定义的拦截器就会发生作用对特定的请求进行拦截了

版权声明:该文观点仅代表作者本人。处理文章:请发送邮件至 三1五14八八95#扣扣.com 举报,一经查实,本站将立刻删除。