概述
SpringMVC 中的 Interceptor 拦截器是非常重要和相当有用的,它的主要作用是拦截指定的用户请求,并进行相应的预处理与后处理。其拦截的时间点在“处理器映射器根据用户提交的请求映射出了所要执行的处理器类,并且也找到了要执行该处理器类的处理器适配器,在处理器适配器执行处理器之前”。当然,在处理器映射器映射出所要执行的处理器类时,已经将拦截器与处理器组合为了一个处理器执行链,并返回给了中央调度器。
自定义拦截器
一般自定义一个拦截器需要实现HandlerInterceptor接口,该接口中有三个方法
1. boolean preHandle()
预先处理请求的方法,此方法有三个参数,分别为request对象、response对象和Object类型的handler对象,handler对象是被拦截的控制器对象
特点
1-执行时机 是在后端控制器方法之前先执行的
2-决定请求是否执行(该方法返回布尔类型的值,真即为放行,假即为拦截不处理)
2. void postHandle()
后端控制器中的方法执行完之后进行处理的方法,此方法有四个参数,分别为request对象、response对象、Object类型的handler对象和ModelAndView对象
特点
1-执行时机 是在后端控制器方法之后执行的
2-能获取到控制器方法执行的结果,可以修改原来的执行结果(可以修改数据或视图)
3-可以做对请求的二次处理
3. void afterCompletion()
该方法是最最最后执行的
此方法有四个参数,分别为request对象、response对象、Object类型的handler对象和Exception对象
该方法的执行有前置条件:该方法所在的类中的preHandler()方法必须执行并返回TRUE
特点
1-执行时机 是在请求处理完成后执行的,TIPS:请求处理的完成标志是 视图处理完成 对视图进行处理后视作请求完成
2-方法体里一般做程序最后需要做的工作,比如释放变量内存等
介绍完之后放一张自定义的拦截器的代码
package com.Sykking.handler;
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;
import java.text.SimpleDateFormat;
import java.util.Date;
public class MyInterceptor implements HandlerInterceptor {
/**
* preHandler:预先处理请求的方法
* @param handler 被拦截的控制器对象
* 特点:
* 1、执行时机 是在后端控制器方法之前先执行的
* 2、对请求做处理
* 3、决定请求是否执行
*/
@Override
public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) throws Exception {
System.out.println("=====preHandler执行了...");
String username = request.getParameter("username");
if (username.equals("Sykking")){
return true;
}else {
request.setAttribute("msg","用户名不正确,应为Sykking");
request.getRequestDispatcher("/tips.jsp").forward(request,response);
return false;
}
}
/**
* @param handler 被拦截的控制器对象
* @param mv 拦截器方法的返回值(请求的执行结果)
* 特点:
* 1、执行时机 是在后端控制器方法之后执行的
* 2、能获取到控制器方法执行的结果,可以修改原来的执行结果(可以修改数据或视图)
* 3、可以做对请求的二次处理
*/
@Override
public void postHandle(HttpServletRequest request, HttpServletResponse response, Object handler, ModelAndView mv) throws Exception {
System.out.println("=====postHandler执行了...");
mv.addObject("CurrentDate",new SimpleDateFormat("yyyy-MM-dd hh:mm:ss").format(new Date()));
mv.setViewName("other");//修改控制器方法里的执行结果 现在转发到other页面
}
/**
*
* @param handler 被拦截的控制器对象
* @param ex 异常对象
* 特点:
* 1、执行时机 是在请求处理完成后执行的,TIPS:请求处理的完成标志是 视图处理完成 对视图进行处理后视作请求完成
* 2、方法体里一般做程序最后需要做的工作,比如释放变量内存等
* 执行条件:
* 1、当前拦截器的preHandler()方法必须执行
* 2、当前拦截器的preHandler()方法必须返回true
*/
@Override
public void afterCompletion(HttpServletRequest request, HttpServletResponse response, Object handler, Exception ex) throws Exception {
System.out.println("======afterCompletion执行了...");
HttpSession session = request.getSession();
Object 临时变量 = session.getAttribute("临时变量");
System.out.println("获取到临时变量="+临时变量);
session.removeAttribute("临时变量");
System.out.println("删除后再次获取临时变量="+session.getAttribute("临时变量"));
}
}
自定义拦截器之后需要在MVC配置文件中声明
有个疑问,为啥我声明了拦截器的拦截规则为全部拦截之后,我的静态资源如js、图片等都走了此拦截器了?我明明配置了静态资源交给tomcat处理了???
多个拦截器的执行顺序
当项目中配置了多个拦截器时,执行顺序是按MVC的配置文件中你配置的顺序自上而下执行的,例如我配置了两个拦截器,都是拦截所有请求的
然后我随便发个请求
图解
最后
以上就是微笑草莓为你收集整理的拦截器Interceptor的全部内容,希望文章能够帮你解决拦截器Interceptor所遇到的程序开发问题。
如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。
发表评论 取消回复