根本链路
参考: 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