zoukankan      html  css  js  c++  java
  • springmvc拦截器的配置

    登陆认证拦截实现

     代码实现

     1 @Controller
     2 public class LoginController {
     3     @RequestMapping("/login")
     4     public String login(HttpSession session,String username,String password) throws Exception {
     5         
     6          session.setAttribute("username", username);
     7          return "redirect:items/queryItems.action";
     8     }
     9     
    10     @RequestMapping("/logout")
    11     public String logout(HttpSession session) throws Exception {
    12         session.invalidate();
    13         return "redirect:/items/queryItems.action";
    14     }
    15 }

    LoginInterceptor.java

     1 public class LoginInterceptor implements HandlerInterceptor {
     2     
     3     //在进入handler方法之前执行
     4     //用于身份认证,身份授权 认认证不通过,拦截,不再向下执行
     5     public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) throws Exception {
     6         
     7         String url = request.getRequestURI();
     8         //判断url是否是公开地址 在这里就是登录提交的地址
     9         if(url.indexOf("login.action") >= 0){
    10             //放行
    11             return true;
    12         }
    13         
    14         HttpSession session = request.getSession();
    15         String username = (String) session.getAttribute("username");
    16         if(username != null){
    17             return true;
    18         }
    19         //失败,跳转登录页面
    20         request.getRequestDispatcher("/WEB-INF/jsp/login.jsp").forward(request, response);
    21         //false表示拦截 true表示放行
    22         return false;
    23     }
    24     
    25     //进入handler方法之后,返回modelandview之前执行
    26     //将公用的模型数据传到视图,也可以在这里统一视图
    27     public void postHandle(HttpServletRequest request, HttpServletResponse response, Object handler, ModelAndView modelAndView)
    28             throws Exception {
    29         System.out.println("Interceptor......postHandle");
    30     }
    31 
    32     //执行完handler方法之后执行
    33     //使用统一的异常处理,统一的日志处理
    34     public void afterCompletion(HttpServletRequest request, HttpServletResponse response, Object handler, Exception ex)
    35             throws Exception {
    36         System.out.println("Interceptor......afterCompletion");
    37     }
    38     
    39 }

     拦截器配置

     1 <!--拦截器 -->
     2 <mvc:interceptors>
     3     <!--多个拦截器,顺序执行 -->
     4     <!-- 登陆认证拦截器 -->
     5     <mvc:interceptor>
     6         <mvc:mapping path="/**"/>
     7         <bean class="cn.cuibusi.ssm.interceptor.LoginInterceptor"></bean>
     8     </mvc:interceptor>
     9 </mvc:interceptors>
  • 相关阅读:
    细说MS事务管理
    大话设计模式(含源码)下载
    CSS基础到提高(PPT、视频、源代码),网页布局不用愁
    Android开发中Layout中明明改了id,但是还出现"cannot be resolved or is not a field"的原因
    读《OO真经》有感,以及我自己的关于哲学的体会
    Web服务小试牛刀
    在Android的RaletiveLayout中,如果空间的相对位置矛盾将不显示此控件
    .net 面试题2
    敏捷软件转
    中英文标点
  • 原文地址:https://www.cnblogs.com/cuibin/p/6891145.html
Copyright © 2011-2022 走看看