zoukankan      html  css  js  c++  java
  • 13_springmvc拦截器应用

    一.实现登录认证

    1.需求:

    用户请求url,拦截器进行拦截校验

             如果请求的url是公开地址(无需登陆即可访问的url),让放行

             如果用户session 不存在跳转到登陆页面

             如果用户session存在放行,继续操作。

    2.登陆controller方法

    package com.ssm.controller;
    
    import com.sun.rowset.internal.WebRowSetXmlReader;
    import org.springframework.stereotype.Controller;
    import org.springframework.web.bind.annotation.RequestMapping;
    
    import javax.servlet.http.HttpSession;
    
    /**
     * Description:1.用户请求登陆,session用户中存在就登陆,反之
     * 如果请求的url公开地址,无需登陆,让他登陆
     * User: jiatp
     * Date: 2019/9/11 0011 下午 6:11
    */
    @Controller
    public class LoginController {
    
        //登陆
        @RequestMapping("/login")
        public String login(HttpSession session,String username,String password ) throws Exception {
            //调用service
    
            session.setAttribute("username",username);
            return "redirect:items/queryItems.action";
        }
    
        //退出
        @RequestMapping("/logout")
        public String  logout(HttpSession session){
    
    
            //清除session
            session.invalidate();
            return "redirect:items/queryItems.action";
        }
    
    
    
    
    }
    

    3.拦截器配置

    package com.ssm.interceptor;
    
    import org.springframework.web.servlet.HandlerInterceptor;
    import org.springframework.web.servlet.ModelAndView;
    
    import javax.servlet.http.HttpServletRequest;
    import javax.servlet.http.HttpServletResponse;
    import javax.servlet.http.HttpSession;
    
    /**
     * Description:登陆验证的拦截器
     * User: jiatp
     * Date: 2019/9/11 0011 下午 4:10
    */
    public class LoginInterceptor implements HandlerInterceptor  {
        /*
         *进入handler方法之前执行,用于身份验证,身份授权
         *如果身份认证没有通过则拦截住不让执行
         *true:放行,false:拦截
         */
        @Override
        public boolean preHandle(HttpServletRequest request,
                                 HttpServletResponse response, Object o) throws Exception {
            //获取请求的url
            String url = request.getRequestURI();
            //判断url是否是公开 地址(实际使用时将公开 地址配置配置文件中)
            //这里公开地址是登陆提交的地址
            if(url.indexOf("login.action")>=0){
                //如果进行登陆提交,放行
                return true;
            }
            HttpSession session = request.getSession();
            //判断session
            String username = (String)session.getAttribute("username");
            if(username!=null){
                //用户存在 放行
                return true;
            }
            //执行这里表示用户身份需要认证,跳转登陆页面
            request.getRequestDispatcher("/WEB-INF/jsp/login.jsp").forward(request,response);
    
    
            return true;
        }
        /*进入handler方法之后,返回modelandView之前执行
        *应用场景从modelAndView出发:将公用的模型数据(比如菜单导航)在这里传到视图,也可以在这里统一指定视图(菜单导航)
        * */
        @Override
        public void postHandle(HttpServletRequest httpServletRequest,
                               HttpServletResponse httpServletResponse, Object o, ModelAndView modelAndView) throws Exception {
            System.out.println("HandlerInterceptor1...postHandle");
    
        }
        /*
        *handler执行完执行此方法,
        * 应用场景:统一异常处理,日志处理等方法
        * */
        @Override
        public void afterCompletion(HttpServletRequest httpServletRequest,
                                    HttpServletResponse httpServletResponse, Object o, Exception e) throws Exception {
            System.out.println("HandlerInterceptor1...afterCompletion");
    
        }
    }
    

    springmvc.xml配置

    测试

  • 相关阅读:
    二叉树遍历
    NO.35 2021/12/13(06:50)[周一]
    NO.29 2021/11/30(06:30)[周二]
    NO.22 2021/11/19(06:15) [周五]
    The .NET ORM Architec
    C#格式字符串
    C# Attribute
    .net DLL反编译文件
    【Beta】Scrum meeting1
    【Alpha】Scrum meeting 6
  • 原文地址:https://www.cnblogs.com/jatpeo/p/11767512.html
Copyright © 2011-2022 走看看