阅读本文需要 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 的主干

本文详细解析了SpringMVC中拦截器的工作原理,重点介绍了登录验证拦截器的应用以及Handler执行过程,包括RequestMappingHandlerAdapter的介入和实际请求处理的深度剖析。
2134

被折叠的 条评论
为什么被折叠?



