Springmvc拦截器执行顺序及各方法作用详解

实现HandlerInterceptor接口或者继承HandlerInterceptor的子类,比如Spring 已经提供的实现了HandlerInterceptor 接口的抽象类HandlerInterceptorAdapter ,下面讲实现其接口的写法,先看一下这个接口的三个方法.

创新互联服务项目包括珠海网站建设、珠海网站制作、珠海网页制作以及珠海网络营销策划等。多年来,我们专注于互联网行业,利用自身积累的技术优势、行业经验、深度合作伙伴关系等,向广大中小型企业、政府机构等提供互联网行业的解决方案,珠海网站推广取得了明显的社会效益与经济效益。目前,我们服务的客户以成都为中心已经辐射到珠海省份的部分城市,未来相信会继续扩大服务区域并继续获得客户的支持与信任!

- 方法preHandle: 顾名思义,该方法将在请求处理之前进行调用,在controller之前执行。SpringMVC 中的Interceptor 是链式的调用的,在一个应用中或者说是在一个请求中可以同时存在多个Interceptor 。每个Interceptor 的调用会依据它的声明顺序依次执行,而且最先执行的都是Interceptor 中的preHandle 方法,所以可以在这个方法中进行一些前置初始化操作或者是对当前请求的一个预处理,比如说获取cookie的值或者判断是否已经登录,也可以在这个方法中进行一些判断来决定请求是否要继续进行下去。该方法的返回值是布尔值Boolean 类型的,当它返回为false 时,表示请求结束,后续的Interceptor 和Controller 都不会再执行;当返回值为true 时就会继续调用下一个Interceptor 的preHandle 方法,如果已经是最后一个Interceptor 的时候就会是调用当前请求的Controller 方法。

- 方法postHandle:由preHandle 方法的解释我们知道这个方法包括后面要说到的afterCompletion 方法都只能是在当前所属的Interceptor 的preHandle 方法的返回值为true 时才能被调用。postHandle 方法,顾名思义就是在当前请求进行处理之后,也就是Controller 方法调用之后执行,但是它会在DispatcherServlet 进行视图返回渲染之前被调用,所以我们可以在这个方法中对Controller 处理之后的ModelAndView 对象进行操作,比如说设置cookie,返回给前端。postHandle 方法被调用的方向跟preHandle 是相反的,也就是说先声明的Interceptor 的postHandle 方法反而会后执行

- 方法afterCompletion:该方法也是需要当前对应的Interceptor 的preHandle 方法的返回值为true 时才会执行。顾名思义,该方法将在整个请求结束之后,也就是在DispatcherServlet 渲染了对应的视图之后执行。这个方法的主要作用是用于进行资源清理工作的。

例:

@Component
public class AuthInterceptor implements HandlerInterceptor {
 private static final String TOKEN_COOKIE = "token";
 @Autowired
 private UserDao userDao;
 @Override
 public boolean preHandle(HttpServletRequest req, HttpServletResponse res, Object handler)
     throws Exception {
  Map map = req.getParameterMap();
  map.forEach((k,v) ->req.setAttribute(k, Joiner.on(",").join(v)));
  String requestURI = req.getRequestURI();
  if (requestURI.startsWith("/static") || requestURI.startsWith("/error")) {
   return true;
  }
  Cookie cookie = WebUtils.getCookie(req, TOKEN_COOKIE);
  if (cookie != null && StringUtils.isNoneBlank(cookie.getValue())) {
    User user = userDao.getUserByToken(cookie.getValue());
    if (user != null) {
     req.setAttribute(CommonConstants.LOGIN_USER_ATTRIBUTE, user);
     UserContext.setUser(user);
    }
  }
  return true;
 }
 @Override
 public void postHandle(HttpServletRequest req, HttpServletResponse res, Object handler,
     ModelAndView modelAndView) throws Exception {
  String requestURI = req.getRequestURI();
  if (requestURI.startsWith("/static") || requestURI.startsWith("/error")) {
   return ;
  }
  User user = UserContext.getUser();
  if (user != null && StringUtils.isNoneBlank(user.getToken())) {
    String token = requestURI.startsWith("logout")? "" : user.getToken();
    Cookie cookie = new Cookie(TOKEN_COOKIE, token);
    cookie.setPath("/");
    cookie.setHttpOnly(false);
    res.addCookie(cookie);
  }
 }
 @Override
 public void afterCompletion(HttpServletRequest req, HttpServletResponse response, Object handler, Exception ex)
     throws Exception {
  UserContext.remove();
 }
}

总结

以上所述是小编给大家介绍的Springmvc拦截器执行顺序及各方法作用详解,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对创新互联网站的支持!


网页名称:Springmvc拦截器执行顺序及各方法作用详解
文章路径:http://scyanting.com/article/jccdcd.html