SpringMVC 执行分为三个阶段

  1. 准备阶段
  2. 匹配阶段
  3. 执行阶段

    准备阶段

  4. 在 Web 容器第一次用到 DispatcherServlet(org.springframework.web.servlet.DispatcherServlet) 的时候,会创建其对象并执行 init 方法

    1. 传统的 SSM 中,DispatcherServlet 是由 Tomcat 来创建的;
    2. 在 SpringBoot 中,DispatcherServlet 是由可以由 Spring 容器来创建;
  5. init 方法内会创建 Spring Web 容器,并调用容器 onRefresh(org.springframework.web.servlet.DispatcherServlet#onRefresh) 方法

image.png

  1. onRefresh 过程中会创建并初始化 SpringMVC 中的重要组件, 例如 HandlerMapping,HandlerAdapter,HandlerExceptionResolver、ViewResolver、MultipartResolver 等
    1. HandlerMapping:路径映射,请求路径找到对应的控制器
    2. HandlerAdapter:调用控制器方法,处理请求
    3. HandlerExceptionResolver:处理 HandlerAdapter 调用控制器方法中的异常
    4. ViewResolver:ModelAndView 或 String 解析到视图对象
    5. MultipartResolver:文件上传时使用
  2. 容器初始化后,会将上一步初始化好的重要组件,赋值给 DispatcherServlet 的成员变量,留待后用

image.png

匹配阶段

  1. 用户发送的请求统一到达前端控制器 DispatcherServlet
  2. DispatcherServlet 遍历所有 HandlerMapping ,找到与路径匹配的处理器
    1. HandlerMapping 有多个,每个 HandlerMapping 会返回不同的处理器对象,谁先匹配,返回谁的处理器。其中能识别 @RequestMapping 的优先级最高
    2. 对应 @RequestMapping 的处理器是 HandlerMethod,它包含了控制器对象和控制器方法信息
    3. 其中路径与处理器的映射关系在 HandlerMapping 初始化时就会建立好

image.png

  1. 将 HandlerMethod 连同匹配到的拦截器,生成调用链对象 HandlerExecutionChain 返回

image.png

  1. 遍历HandlerAdapter 处理器适配器,找到能处理 HandlerMethod 的适配器对象,开始调用

image.png

执行阶段

  1. 执行拦截器 preHandle

image.png

  1. 由 HandlerAdapter 调用 HandlerMethod
  • 调用前处理不同类型的参数
  • 调用后处理不同类型的返回值

image.png

  1. 第 2 步没有异常
    1. 返回 ModelAndView
    2. 执行拦截器 postHandle 方法
    3. 解析视图,得到 View 对象,进行视图渲染

image.png

  1. 第 2 步有异常,进入 HandlerExceptionResolver 异常处理流程

image.png

  1. 最后都会执行拦截器的 afterCompletion 方法
  2. 如果控制器方法标注了 @ResponseBody 注解,则在第 2 步,就会生成 json 结果,并标记 ModelAndView 已处理,这样就不会执行第 3 步的视图渲染