SpringMVC 中的 Interceptor 拦截器也是相当重要和相当有用的,它的主要作用是拦截用户的请求并进行相应的处理。比如通过它来进行权限验证,或者是来判断用户是否登陆等操作。
SpringMVC 拦截器的定义方式
- 实现接口
- 继承适配器
案例实操
实现接口
实现 HandlerInterceptor 接口方式定义我们的拦截器代码如下:
public class MyInterceptor implements HandlerInterceptor{
/**
* preHandle 在请求方法拦截前执行
* 返回 true 代表对当前请求进行放行处理
*/
@Override
public boolean preHandle(HttpServletRequest request,
HttpServletResponse response, Object handler) throws Exception {
System.out.println("action 之前执行!!!");
return true; //继续执行 action
}
/**
* 请求执行后,生成视图前执行
*/
@Override
public void postHandle(HttpServletRequest request,
HttpServletResponse response, Object handler,
ModelAndView modelAndView) throws Exception {
System.out.println("Action 执行之后,生成视图之前执行!!");
}
/**
* 在请求方法执行后进行拦截
*/
@Override
public void afterCompletion(HttpServletRequest request,
HttpServletResponse response, Object handler, Exception ex)
throws Exception {
System.out.println("方法执行后进行拦截。。释放资源。。。");
}
}
对应配置有两种方式:
配置方式一(拦截所有请求配置方式):
<mvc:interceptors>
<!-- 使用 bean 定义一个 Interceptor
直接定义在 mvc:interceptors 根下面的 Interceptor 将拦截所有的请求 -->
<bean class="com.xxx.interceptors.MyInterceptor" />
</mvc:interceptors>
配置方式二(拦截指定请求配置方式)
mvc:interceptors
<mvc:interceptor>
<mvc:mapping path="/test/*.do" />
<bean class="com.xxx.interceptors.MyInterceptor" />
</mvc:interceptor>
</mvc:interceptors>
效果:
请求地址: http://localhost:8080/springmvc03/test/hello.do
控制台打印结果信息:
多个拦截器配置(多个拦截器组成一个拦截器链 ,栈式结构 123 321 退出):
<mvc:interceptors>
<mvc:interceptor>
<!-- 拦截所有请求 -->
<mvc:mapping path="/**" />
<bean class="com.xxx.interceptors.MyInterceptor" />
</mvc:interceptor>
<mvc:interceptor>
<!-- 拦截所有请求 -->
<mvc:mapping path="/**" />
<bean class="com.xxx.interceptors.MyInterceptor2" />
</mvc:interceptor>
</mvc:interceptors>
继承适配器
继承 HandlerInterceptorAdapter 方式定义拦截器(实际上最终还是 HandlerInterceptor 接口实现)
public class MyInterceptor2 extends HandlerInterceptorAdapter{
/**
* 重写 preHandle 请求执行前执行
*/
@Override
public boolean preHandle(HttpServletRequest request,
HttpServletResponse response, Object handler) throws Exception {
System.out.println("请求前执行。。。");
return true;
}
}
扩展
使用拦截器完成用户是否登录请求验证拦截器定义:
public class LoginInterceptor implements HandlerInterceptor{
/**
* 方法拦截前执行
*/
@Override
public boolean preHandle(HttpServletRequest request,
HttpServletResponse response, Object handler) throws Exception {
User user= (User) request.getSession().getAttribute("user");
/**
* 判断 uri 是否包含路径
* 包含就放行
*/
if(request.getRequestURI().indexOf("userLogin.do")>-1){
return true;
}
/**
* 判断 session user 是否为空
*/
if(null==user){
response.sendRedirect(request.getContextPath()+"/login.jsp");
return false;
}
return true; //继续执行 action
}
@Override
public void postHandle(HttpServletRequest request,
HttpServletResponse response, Object handler,
ModelAndView modelAndView) throws Exception {
System.out.println("Action 执行之后,生成视图之前执行!!");
}
/**
* 在方法执行后进行拦截
*/
@Override
public void afterCompletion(HttpServletRequest request,
HttpServletResponse response, Object handler, Exception ex)
throws Exception {
System.out.println("方法执行后进行拦截。。释放资源。。。");
}
}
UserController 类
/**
\*
\* @author Administrator
\* 模拟 用户操作
*/
@Controller
@RequestMapping("/user")
public class UserLoginController {
@RequestMapping("/userLogin")
public ModelAndView userLogin(HttpServletRequest request){
ModelAndView mv=new ModelAndView();
User user=new User();
user.setUserName("xxx");
user.setUserPwd("123456");
request.getSession().setAttribute("user", user);
mv.setViewName("success");
return mv;
}
@RequestMapping("/addUser")
public ModelAndView addUser(){
System.out.println("添加用户记录。。。");
ModelAndView mv=new ModelAndView();
mv.setViewName("success");
return mv;
}
@RequestMapping("/delUser")
public ModelAndView delUser(){
ModelAndView mv=new ModelAndView();
mv.setViewName("success");
return mv;
}
@RequestMapping("/updateUser")
public ModelAndView updateUser(){
ModelAndView mv=new ModelAndView();
mv.setViewName("success");
return mv;
}
}
拦截器 xml 配置
<!-- 拦截所有请求 -->
<mvc:interceptors>
<mvc:interceptor>
<mvc:mapping path="/**" />
<bean class="com.xxx.interceptors.LoginInterceptor" />
</mvc:interceptor>
</mvc:interceptors>