
这张图展示的是 Spring MVC 最经典的工作流 。既然你之前问过 DispatcherServlet,那我们就把这张图里的角色和具体的组件对号入座,带你走一遍这个"请求大冒险"。
在 Spring MVC 中,图里的 Front Controller 对应的真实身份就是 DispatcherServlet。
🚀 Spring MVC 请求处理全过程
我们可以把这个过程想象成:你去餐厅吃饭,从进门到菜端上桌的过程。
1. Incoming Request(顾客进门)
- 动作 :浏览器发起一个请求(比如输入
www.community.com/index)。 - 对应 :请求首先到达 Servlet 容器(比如图下方的 Tomcat )。Tomcat 发现这是找 Spring 的,就把它交给了 Front Controller (也就是我们的"大管家"
DispatcherServlet)。
2. Delegate Request(前台分发)
- 动作 :大管家看了一下请求的路径,心里想:"哦,这是找
/index的,该派谁去干活呢?" - 对应 :它会查阅一张表(HandlerMapping),找到对应的 Controller(业务处理员)。
3. Handle Request & Create Model(厨师炒菜 & 准备盘子)
- 动作 :Controller 拿到请求后,开始执行你的业务逻辑(比如去数据库查帖子列表)。
- 对应 :
- Handle Request:执行具体的 Java 方法。
- Create Model :处理完后,Controller 会把数据塞进一个叫 Model 的容器里(就像炒好的菜放在盘子里),并告诉大管家:"活干完了,数据在 Model 里,请把这些数据发给名叫
index.html的模版去展示。"
4. Delegate rendering of response(移交装盘)
- 动作 :大管家(Front Controller)拿到 Model 和目标 View 的名字。
- 对应 :它不会自己去画网页,而是把 Model 交给 View Template(视图模板,比如 Thymeleaf 或 JSP)。
5. Render Response(最后摆盘)
- 动作 :View Template 拿着 Model 里的数据,填进 HTML 模板的占位符里。
- 对应 :比如把 Model 里的"用户名"填到网页右上角。这个过程叫 渲染(Render)。
6. Return control & Return Response(服务员上菜)
- 动作:渲染好的 HTML 页面返回给大管家,大管家再把它通过网络发回给浏览器。
- 对应:你最终在屏幕上看到了漂亮的网页。
💡 核心总结:谁干了什么?
| 图中名称 | 对应 Spring 组件 | 核心职责 |
|---|---|---|
| Front Controller | DispatcherServlet | 调度员。负责统筹全局,不干苦力活,只负责派活。 |
| Controller | 标注了 @Controller 的类 |
业务员。负责处理逻辑、查数据库、准备数据(Model)。 |
| Model | Model / ModelAndView | 数据载体。存放 Controller 产生的数据。 |
| View Template | Thymeleaf / FreeMarker | 渲染员。负责把数据和 HTML 结合,生成用户能看的页面。 |
🎯 帮你划重点(面试爱考)
图中显示这是一个 High Level(高层) 的视图。在真正的"八股文"里,其实在 Front Controller 和 Controller 之间还藏着两个小助手:
- HandlerMapping:帮大管家找哪个 Controller 能处理这个请求。
- HandlerAdapter:因为 Controller 的写法多种多样,这个适配器负责真正去"调用"那个方法。
多问一句:
现在的开发模式大多是 "前后端分离" 。如果是那种不返回网页、只返回 JSON 数据(比如给手机 App 用)的接口,这个流程图里哪一步会被"砍掉"或者发生变化,你能猜到吗?(提示:看 View Template 那一部分)