阅读本文需要 10 分钟
tips:本文属于 Spring MVC 请求流程 - 基于源码解读 的小分支
拦截器
-
在执行 handler 的前后,都会先走一遍拦截器
-
查看
applyPreHandle
,里面调用了HandlerInterceptor
的preHandler
方法
-
登陆验证拦截其实就是实现这个方法,如果
preHandle
返回 false ,那么applyPreHandle
就会返回 false,直接 return,后面的 handle 也就无法执行了
执行Handle
-
当前适配器是
RequestMappingHandlerAdapter
,调用的是父类AbstractHandlerMethodAdapter
的handle
-
进去,然后调用了
handleInternal
,这个方法的实现类是RequestMappingHandlerAdapter
-
进入
handleInternal
,发现有个方法invokeHandlerMethod
出现了3次,该方法负责处理由@RequestMapping注解编写的 handler,并且返回模型和逻辑视图
-
invokeHandlerMethod 内部处理比较复杂,我们直接跳到最后
-
查看
ServletInvocableHandlerMethod
的invokeAndHandle
,里面还有一层InvocableHandlerMethod#invokeForRequest,里面的doInvoke
就是真正处理请求的方法
-
查看 doInvoke,里面就是反射调动,也从另一个方面说明,为什么Handler要保存bean
-
最后再画个序列图理清执行 handle 的主干