Spring MVC 执行流程全解析:从请求到响应的七步走

Spring MVC 的工作流程,漏了这一个今天刚好面试提到了,没回答出来,记录一下。

🧭 Spring MVC 整体执行流程一览(从请求到响应)

✅ 1. 请求发出:浏览器发送 HTTP 请求

如用户访问:

复制代码
http://localhost:8080/user/list

✅ 2. DispatcherServlet 接收请求(前端控制器)

  • 职责: Spring MVC 的入口点,负责整个请求的调度与分发。
  • web.xml 或 Spring Boot 的自动配置中,DispatcherServlet 会映射所有请求(如:/)。

✅ 3. HandlerMapping 查找处理器(Controller)

  • DispatcherServlet 通过 HandlerMapping 查找能处理当前 URL 的 Controller 及其方法。
  • 默认实现如:RequestMappingHandlerMapping

✅ 4. HandlerAdapter 调用目标方法

  • 查找到 Controller 方法后,由 HandlerAdapter 调用这个方法。
  • 常用的是 RequestMappingHandlerAdapter
  • 支持参数解析器、返回值处理器等扩展点。

✅ 5. Controller 处理请求

  • 具体业务逻辑执行,返回一个 ModelAndView 对象或其他响应体,其中包含模型数据和逻辑视图名。

    java 复制代码
    @Controller
    public class UserController {
        @GetMapping("/user/list")
        public String list(Model model) {
            model.addAttribute("users", userService.findAll());
            return "userList";  // 返回逻辑视图名
        }
    }

✅ 6. ViewResolver 视图解析器定位视图

  • 根据 Controller 返回的逻辑视图名(如 "userList"),由 ViewResolver 解析成实际视图路径(如:/WEB-INF/views/userList.jsp)。
  • Spring Boot 默认用的是 Thymeleaf 或 JSP。

✅ 7. 渲染视图 & 返回响应

  • 渲染视图并将结果写入 HTTP 响应,响应浏览器。

Spring MVC 虽然整体流程复杂,但是实际开发中很简单,大部分的组件不需要我们开发人员创建和管理,真正需要处理的只有 ControllerViewModel

在前后端分离的情况下,步骤 6、7会略有不同,后端通常只需要处理数据,并将 JSON 格式的数据返回给前端就可以了,而不是返回完整的视图页面。


说说 Handler ?为什么还需要 HandlerAdapter

Handler 一般就是指 Controller,Controller 是 Spring MVC 的核心组件,负责处理请求,返回响应。

Spring MVC 允许使用多种类型的处理器。不仅仅是标准的 @Controller 注解的类,还可以是实现了特定接口的其他类(如 HttpRequestHandler 或 SimpleControllerHandlerAdapter 等)。这些处理器可能有不同的方法签名和交互方式。

HandlerAdapter 的主要职责就是调用 Handler 的方法来处理请求,并且适配不同类型的处理器。HandlerAdapter 确保 DispatcherServlet 可以以统一的方式调用不同类型的处理器,无需关心具体的执行细节。

🔁 总流程图(Mermaid)


📚 场景举例:用户管理系统

步骤 描述
用户访问 /user/list 浏览器发出请求
DispatcherServlet 拦截 前端控制器统一处理
HandlerMapping 匹配到 UserController.list() 方法负责处理用户列表
返回逻辑视图 userList 将用户数据加入 Model
ViewResolver 映射到 /WEB-INF/views/userList.jsp 渲染用户列表页面
最终页面展示给用户 请求-响应闭环完成

💡 面试延伸问题(必须掌握)

面试高频问题 应答思路
DispatcherServlet 的职责是什么? 核心调度器,协调请求流程
HandlerMapping 是如何工作的? 根据 URL 匹配 Controller 方法
ViewResolver 支持哪些视图? JSP、Thymeleaf、FreeMarker 等
如何自定义参数解析器? 实现 HandlerMethodArgumentResolver

🧠 源码阅读入口建议

模块 源码入口类
DispatcherServlet org.springframework.web.servlet.DispatcherServlet
HandlerMapping RequestMappingHandlerMapping
HandlerAdapter RequestMappingHandlerAdapter
ViewResolver InternalResourceViewResolver

🧵 总结一句话:

Spring MVC 中,DispatcherServlet 是核心协调者,通过一系列策略接口(HandlerMapping、HandlerAdapter、ViewResolver 等)完成从请求分发到视图渲染的完整链路。

相关推荐
copyer_xyf6 分钟前
Agent RAG
后端·python·agent
copyer_xyf9 分钟前
【RAG】向量数据库:milvus
后端·python·agent
铁皮饭盒10 分钟前
Bun 哪比 Node.js 快?
javascript·后端
copyer_xyf25 分钟前
Agent 记忆管理
后端·python·agent
葫芦和十三7 小时前
图解 MongoDB 02|BSON:你以为存的是 JSON,其实是带类型的二进制
后端·mongodb·agent
葫芦和十三7 小时前
图解 MongoDB 01|文档数据库
后端·mongodb·agent
陈随易9 小时前
VSCode的Copilot扩展支持接入DeepSeek,Kimi了!
前端·后端·程序员
我不是外星人11 小时前
有了 Harness Engineering ,真的还需要研发工程师吗?
前端·后端·ai编程
candyTong11 小时前
RTK 技术原理:一次典型会话里,80% 上下文是怎么省下来的
javascript·后端·架构
Rust研习社13 小时前
组合真的优于继承吗?为什么 Rust 和 Go 都拥抱组合舍弃继承?
后端·rust·编程语言