springmvc-调用链路

根本链路

参考: click

会为该请求创建一个过滤器链,过滤器中的过滤器都执行完之后,才会调用Servlet的service方法,如果我们使用SpringMVC的话,最终调用的是DispatcherServlet的doDispatch方法,在该方法会根据当前请求路径、请求头、请求参数等信息确定执行处理器handler(也就是我们的Controller的类中配置了@RequestMapping注解的方法),此时返回的handler是HandlerExecutionChain处理器执行链,该执行链中含适用的拦截器以及具体处理的方法(@RequestMapping注解的方法),然后正向执行每个拦截器的preHandle方法,再通过该handler找到处理器适配器,使用处理器适配器执行具体的方法(@RequestMapping注解的方法),再反向执行每个拦截器的postHandle方法,最后反向执行每个拦截器的afterCompletion方法,最后的最后将返回结果通过Response将返回结果写回客户端。


// 调用Engine的Pipeline
connector.getService().getContainer().getPipeline().getFirst().invoke(request, response);
// StandardEngineValve调用Host的Pipeline
host.getPipeline().getFirst().invoke(request, response);
// StandardHostValve调用Context的Pipeline
context.getPipeline().getFirst().invoke(request, response);
// StandardContextValve调用Wrapper的Pipeline
wrapper.getPipeline().getFirst().invoke(request, response);
// StandardWrapperValve创建过滤器链并调用
filterChain.doFilter(request.getRequest(), response.getResponse());
// DispatcherServlet.service()
servlet.service(request, response);
// DispatcherServlet.doDispatch()
doDispatch(request, response);
// 执行拦截器链的preHandle()--正向执行
mappedHandler.applyPreHandle(processedRequest, response);
// 执行具体的handler,也就是@RequestMapping注解的方法
ha.handle(processedRequest, response, mappedHandler.getHandler());
// 执行拦截器链的postHandle()--反向执行
mappedHandler.applyPostHandle(processedRequest, response, mv);
// 执行拦截器链的afterCompletion()--反向执行
mappedHandler.triggerAfterCompletion(request, response, null);

1 ## ApplicationFilterChain
在这里插入图片描述

2 DispatcherServlet

在这里插入图片描述

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值