springmvc拦截器

来源:互联网 发布:唐青枫官方捏脸数据 编辑:程序博客网 时间:2024/06/05 00:42

1、拦截器定义

定义拦截器,实现HandlerInterceptor接口。接口中提供三个方法。

public classHandlerInterceptor1implementsHandlerInterceptor {

   //进入 Handler方法之前执行

   //用于身份认证、身份授权

   //比如身份认证,如果认证不通过表示当前用户没有登陆,需要此方法拦截不再向下执行

   @Override

   public booleanpreHandle(HttpServletRequest request,

         HttpServletResponseresponse, Object handler) throws Exception {

     

      //return false表示拦截,不向下执行

      //return true表示放行

      return false;

   }

 

   //进入Handler方法之后,返回modelAndView之前执行

   //应用场景从modelAndView出发:将公用的模型数据(比如菜单导航)在这里传到视图,也可以在这里统一指定视图

   @Override

   public voidpostHandle(HttpServletRequest request,

         HttpServletResponseresponse, Object handler,

         ModelAndViewmodelAndView) throwsException {

     

    

   }

 

   //执行Handler完成执行此方法

   //应用场景:统一异常处理,统一日志处理

   @Override

   public voidafterCompletion(HttpServletRequest request,

         HttpServletResponseresponse, Object handler, Exception ex)

         throws Exception {

     

     

   }

 

}

2、拦截器配置

2.1针对HandlerMapping配置

springmvc拦截器针对HandlerMapping进行拦截设置,如果在某个HandlerMapping中配置拦截,经过该HandlerMapping映射成功的handler最终使用该拦截器。

<bean

    class="org.springframework.web.servlet.handler.BeanNameUrlHandlerMapping">

    <propertyname="interceptors">

       <list>

           <ref bean="handlerInterceptor1"/>

           <ref bean="handlerInterceptor2"/>

       </list>

    </property>

</bean>

    <beanid="handlerInterceptor1"class="com.txr.handler.HandlerInterceptor1"/>

    <bean id="handlerInterceptor2"class="com.txr.handler.HandlerInterceptor2"/>

但是一般不推荐使用

2.2 类似全局的拦截器

springmvc配置类似全局的拦截器,springmvc框架将配置的类似全局的拦截器注入到每个HandlerMapping中。

在springmvc-servlet中添加如下代码



2.3 编写俩个拦截




测试

当俩个拦截器都放行时也就是都返回true时控制台信息

HandlerInterceptor1...preHandle

HandlerInterceptor2...preHandle

 

HandlerInterceptor2...postHandle

HandlerInterceptor1...postHandle

 

HandlerInterceptor2...afterCompletion

HandlerInterceptor1...afterCompletion

总结:

preHandle方法按顺序执行,

postHandle和afterCompletion按拦截器配置的逆向顺序执行。

当1放行 2不放行控制台消息

HandlerInterceptor1...preHandle

HandlerInterceptor2...preHandle

HandlerInterceptor1...afterCompletion


总结:

拦截器1放行,拦截器2 preHandle才会执行。

拦截器2 preHandle不放行,拦截器2 postHandle和afterCompletion不会执行。

只要有一个拦截器不放行,postHandle不会执行。


拦截器1不放行,2不放行控制台消息

HandlerInterceptor1...preHandle


总结:

拦截器1 preHandle不放行,postHandle和afterCompletion不会执行。

拦截器1 preHandle不放行,拦截器2不执行。


2.4根据以上总结

根据测试结果,对拦截器应用。

 

比如:统一日志处理拦截器,需要该拦截器preHandle一定要放行,且将它放在拦截器链接中第一个位置。

 

比如:登陆认证拦截器,放在拦截器链接中第一个位置。权限校验拦截器,放在登陆认证拦截器之后。(因为登陆通过后才校验权限)

3、拦截器应用(实现登录认证)


3.1需求

1、用户请求url
2、拦截器进行拦截校验
如果请求是url是公开地址(无需登录即可访问的url),让放行
如果用户session不存在跳转到登录页面
如果用户session存在放行,继续操作。

3.2登录controller方法


3.3 登录认证拦截器实验

  3.3.1代码实现

publicclassLoginInterceptor implements HandlerInterceptor {

 

  

   //进入 Handler方法之前执行

   //用于身份认证、身份授权

   //比如身份认证,如果认证通过表示当前用户没有登陆,需要此方法拦截不再向下执行

   @Override

   publicbooleanpreHandle(HttpServletRequest request,

         HttpServletResponseresponse, Object handler)throws Exception {

     

      //获取请求的url

      Stringurl = request.getRequestURI();

      //判断url是否是公开地址(实际使用时将公开地址配置配置文件中)

      //这里公开地址是登陆提交的地址

      if(url.indexOf("login.action")>=0){

         //如果进行登陆提交,放行

         returntrue;

      }

     

      //判断session

      HttpSessionsession  = request.getSession();

      //session中取出用户身份信息

      Stringusername = (String) session.getAttribute("username");

     

      if(username !=null){

         //身份存在,放行

         returntrue;

      }

     

      //执行这里表示用户身份需要认证,跳转登陆页面

      request.getRequestDispatcher("/WEB-INF/jsp/login.jsp").forward(request, response);

     

      //return false表示拦截,不向下执行

      //return true表示放行

      returnfalse;

   }




3.3.2 拦截器配置











0 0
原创粉丝点击