• 路径 org.spring work.web.servlet.DispatcherServlet
  • 继承关系
    image.png
  • 重点关注doService()方法

    • 该方法重写了父类 workServlet的方法
    • workServletprocessRequest()方法中调用了doService()方法
    • processRequest()方法是在 workServlet(继承自HttpServlet,重写了doGet(),doPost()....)中的doGet(),doPost()....中调用的

所以整个过程是DispatcherServlet响应/所有请求。容器调用HttpServletservice()方法,该方法根据HttpMethod分别调用doGet(),doPost()...等方法, workServlet重写了doGet(),doPost()...等方法,并在方法中调用processRequest()方法,processRequest()方法再调用(重写 workServlet)DispatcherServlet.doService()方法,请求即到了DispatcherServlet.

  • 重点关注doDispatch(request, response)方法
    image.png
  • 查找能够响应当前请求的处理器
// Determine handler for the current request.mappedHandler = getHandler(processedRequest);

image.png
image.png

  • Spring容器启动时根据@Controller注解和@RequestMapping获取对应的HandlerMethod
    image.png
  • 得到处理类与处理方法
    image.png
  • 继续往下,走到HandlerExecutionChain executionChain = getHandlerExecutionChain(handler, request);
  • 在方法getHandlerExecutionChain(handler, request)中添加需要拦截该请求的拦截器
    image.png
  • 方法getHandlerExecutionChain(handler, request)执行完毕之后可以拿到的数据:
    image.png
  • 返回 Dispatcher.getHandler(processedRequest)
    image.png
  • 依次执行每个拦截器InterceptorList中的预处理方法preHandler()
    image.png
  • 执行真正的业务方法
    image.png
  • 依次执行每个拦截器的postHandler()方法
    image.png
  • processDispatchResult(processedRequest, response, mappedHandler, mv, dispatchException)处理返回值与执行拦截器的afterCompletion()方法
    image.png
  • 依次执行每个拦截器的afterCompletion()方法
    image.png

一次请求执行完毕

  • 调试时长:12分钟
    image.png
收藏 打印