spring拦截器原理

本文介绍了Spring MVC中的HandlerInterceptor接口,用于自定义拦截器。内容包括preHandle()、postHandle()和afterCompletion()三个方法的详细解释,它们分别在请求处理前后和整个请求结束后执行。此外,还提及了拦截器的配置方式,包括XML配置和控制器样例,以及拦截器如何进行权限校验的例子。
摘要由CSDN通过智能技术生成

   HandlerInterceptor接口------自定义拦截器

通过一下三个方法对用户的请求进行处理

  1. preHandle(): 这个方法在业务处理器处理请求之前被调用,SpringMVC 中的Interceptor是链式调用的,在一个应用中或者说是在一个请求中可以同时存在多个Interceptor。每个Interceptor 的调用会依据它的声明顺序依次执行,而且最先执行的都是Interceptor中的preHandle 方法,所以可以在这个方法中进行一些前置初始化操作或者是对当前请求的一个预处理,也可以在这个方法中进行一些判断来决定请求是否要继续进行下去。该方法的返回值是布尔值Boolean 类型的,当它返回为false 时,表示请求结束,后续的Interceptor 和Controller都不会再执行;当返回值为true 时就会继续调用下一个Interceptor 的preHandle 方法,如果已经是最后一个Interceptor 的时候就会是调用当前请求的Controller 方法。

  2.      postHandle():这个方法在当前请求进行处理之后,也就是Controller方法调用之后执行,但是它会在DispatcherServlet 进行视图返回渲染之前被调用,所以我们可以在这个方法中对Controller处理之后的ModelAndView 对象进行操作。postHandle 方法被调用的方向跟preHandle 是相反的,也就是说先声明的Interceptor 的postHandle 方法反而会后执行//介于controller后和返回视图前

  3.      afterCompletion():该方法也是需要当前对应的Interceptor 的preHandle 方法的返回值为true 时才会执行。顾名思义,该方法将在整个请求结束之后,也就是在DispatcherServlet渲染了对应的视图之后执行这个方法的主要作用是用于进行资源清理工作的afterCompletion方法被调用的方向和preHandle也是相反的,先声明的Interceptor的afterCompletion方法后执行。

public classLoginInterceptor implements HandlerInterceptor {
 
   //在执行Controller方法之前来执行的
   //用于用户认证校验、用户权限校验
   @Override
   public boolean preHandle(HttpServletRequest request,
         HttpServletResponseresponse, Object handler) throws Exception {
     
      //得到请求的url
      Stringurl = request.getRequestURI();
     
      //判断是否是公开地址
      //实际开发中需要公开地址配置在配置文件中
      if(url.indexOf("login.action")>=0){
         //如果是公开地址则放行
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值