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>