1. 执行doDispatcher做请求分发处理

  2. 1016行,调用 getHandler() 方法 (关键类 RequestMappingHandlerMapping )

    • 返回目标方法(目标处理器)
    • 返回拦截器链( 当前方法可能执行的所有拦截器 )
      源码解析:SpringMVC 拦截器执行时机
  3. 1035行,mappedHandler.applyPreHandle () 执行所有拦截器的前置方法 → preHandle()
    源码解析:SpringMVC 拦截器执行时机

  4. applyPreHandle()方法中,将与目标处理器关联的所有拦截器进行正序遍历,遍历执行所有拦截器的preHandle()方法
    源码解析:SpringMVC 拦截器执行时机

  5. 执行完后回到dispatch()方法继续执行,在1047行,执行所有拦截器的后置方法源码解析:SpringMVC 拦截器执行时机

  6. applyPostHandle()方法中,倒序遍历执行所有拦截器的postHandle()方法
    源码解析:SpringMVC 拦截器执行时机

  7. 1057行,执行 processDispatchResult()方法 处理模型和视图
    源码解析:SpringMVC 拦截器执行时机

  8. 进入processDispatchResult()方法中,在1118行执行render()方法进行渲染
    源码解析:SpringMVC 拦截器执行时机

  9. 渲染完后,最后在render()方法的最后,1136行执行triggerAfterCompletion()方法
    源码解析:SpringMVC 拦截器执行时机

  10. triggerAfterCompletion()方法中,和前面的applyPostHandle()方法一样,这里也是倒序遍历执行拦截器的afterCompletion()方法
    源码解析:SpringMVC 拦截器执行时机

  11. 执行完render()后回到doDispatch()方法,继续执行剩余代码

相关文章: