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 等)完成从请求分发到视图渲染的完整链路。

相关推荐
Sammyyyyy13 分钟前
Node.js 做 Web 后端优势为什么这么大?
开发语言·前端·javascript·后端·node.js·servbay
小薛博客19 分钟前
BigDecimal的使用
java
你我约定有三34 分钟前
软件启动时加配置文件 vs 不加配置文件
java·分布式·zookeeper
重庆穿山甲40 分钟前
Cola架构深度解析:企业级应用架构设计指南
后端
27^×41 分钟前
Java 内存模型与垃圾回收机制详解
java·开发语言
syty202042 分钟前
flink 伪代码
java·windows·flink
IT_陈寒1 小时前
🔥5个必学的JavaScript性能黑科技:让你的网页速度提升300%!
前端·人工智能·后端
你好~每一天1 小时前
2025年B端产品经理进阶指南:掌握这些计算机专业技能,决胜职场!
java·人工智能·经验分享·学习·产品经理·大学生
莫克2 小时前
java文件上传
后端
LeonMinkus2 小时前
dubbo3使用grpc开发分布式服务
后端