10、SpringMVC拦截器案例

SpringMVC--拦截器--Interceptor--案例

1、根据demo9的案例测试规划用户登录拦截

1.1、自定义拦截器的三大要素

  • 创建拦截器类--实现HandlerInterceptor接口,实现方法(proHandle,postHandle,afterCompletion),这里只实现第一个就行
  • Springmvc的配置文件--规划拦截器
  • 方法测试

1.2、创建拦截器类,实现接口的方法

1、概述

  • 除登录请求的所有请求都需要经过这个拦截器,如果session域中不含用户的对象,说明用户是通过非法路径进入的,需要重定向到登录页面

2、设计(MyInterceptor3)

public class MyInterceptor3 implements HandlerInterceptor {
    // 如果不报错那就让这玩意儿运行嘛
    @Override
    public boolean preHandle(HttpServletRequest request,
                             HttpServletResponse response,
                             Object handler) throws Exception {
        // 获取session对象
        HttpSession session = request.getSession();
        // 获取到session域中存储的User对象
        User user = (User) session.getAttribute("user");
        System.out.println("user的信息为:"+user);
        if(user==null){
            //重定向到登录页面
            response.sendRedirect("http://localhost:8080/"
            +request.getContextPath()+"/login.html");
            return false;
        }
        System.out.println("那就是莫问题咯~");
        return true;
    }
}

1.3、规划SpringMVC的配置文件,设置拦截器

前情提要,需要规划拦截器interceptor,需要使用mvc标签中的interceptors,因为拦截器是一个链条

1、拦截器配置的参数详解

  • mvc:interceptors:拦截器链条
  • mvc:interceptor:需要配置的拦截器(一个)
    • mvc:mapping:拦截的内容为
    • mvc: exclude-mapping: 除了什么资源不拦截
    • bean:自定义拦截器的全限定名

2、开始配置

  • <!-- 配置自定义拦截器 -->
    <mvc:interceptors>
        <mvc:interceptor>
            <!-- 全部资源进行拦截 -->
            <mvc:mapping path="/**" />
            <!-- 除了Login不进行拦截 -->
            <mvc:exclude-mapping path="/user/login"/>
            <mvc:exclude-mapping path="/login.html"/>
            <bean class="com.waves.com.waves.intercepter.MyInterceptor3"></bean>
        </mvc:interceptor>
    </mvc:interceptors>
    
posted @ 2022-10-05 20:05  澜璨  阅读(60)  评论(0)    收藏  举报