-
执行
doDispatcher做请求分发处理 -
在1016行,调用
getHandler()方法 (关键类 RequestMappingHandlerMapping )- 返回目标方法(目标处理器)
- 返回拦截器链( 当前方法可能执行的所有拦截器 )
-
在1035行,
mappedHandler.applyPreHandle ()执行所有拦截器的前置方法 →preHandle() -
在
applyPreHandle()方法中,将与目标处理器关联的所有拦截器进行正序遍历,遍历执行所有拦截器的preHandle()方法 -
执行完后回到
dispatch()方法继续执行,在1047行,执行所有拦截器的后置方法 -
在
applyPostHandle()方法中,倒序遍历执行所有拦截器的postHandle()方法 -
在1057行,执行
processDispatchResult()方法 处理模型和视图 -
进入
processDispatchResult()方法中,在1118行执行render()方法进行渲染 -
渲染完后,最后在
render()方法的最后,1136行执行triggerAfterCompletion()方法 -
在
triggerAfterCompletion()方法中,和前面的applyPostHandle()方法一样,这里也是倒序遍历执行拦截器的afterCompletion()方法 -
执行完
render()后回到doDispatch()方法,继续执行剩余代码
相关文章: