Spring MVC源码-核心架构与请求处理流程

MVC是我们学习Spring架构绕不过去的一块内容,并且在日常开发生活中早已成为了一种规范,所谓的MVC就是 Model-View-Controller:模块-视图-控制器,是将业务逻辑、用户界面和数据模型 分开,是专门应用于开发Web应用程序。通过DispatcherServelt前端控制器,MVC管理传进来的HTTP请求,并将请求派发给相应的控制器进行处理。

1. 核心架构

图片来源于:pdai.tech/md/spring/s...

我们可以看到,Spring MVC的核心架构以DispatcherServelt为中心,DispatcherServelt是整个架构的入口点,负责接收并分发HTTP的请求。我们可以看到这些有这些组件:

  • DispatcherServelt:前端控制器,接受请求、分发请求
  • HandlerMapping:将请求映射到具体的控制器
  • HandlerAdapter:适配器,用于调用控制器方法,支持不同类型的控制器
  • ViewResolver:将逻辑视图名解析为实际的视图对象
  • View:渲染模型数据,生成最终响应,如HTML或者JSON
  • Controller:处理请求的业务逻辑,这也是我们在写接口的时候最直接接触的

2. 请求处理流程

MVC的请求处理流程是理解其工作原理的关键,我们先整体看一下整个请求流程是什么:

  • 客户端发送请求:用户通过浏览器发送HTTP请求,指定特定的URL
  • DispatcherServlet:前端控制器拦截所有传入的请求
  • HandlerMapping映射请求DispatcherServlet使用HandlerMapping确定哪个控制器处理该请求,根据URL和HTTP方法(GET、POST)找到匹配的控制器方法
  • HandlerAdapter调用控制器 :找到控制器后,HandlerAdapter执行控制器方法,处理业务逻辑,可能调用服务层或数据访问层,并返回视图名
  • ViewResolver解析视图 :返回的视图名,DispatcherServlet使用ViewResolver将逻辑视图名解析为实际视图
  • 视图渲染:视图使用模型数据渲染生成了最终响应内容
  • 返回响应DispatcherServlet将渲染后的视图作为HTTP响应返回给客户端

客户端 -> HTTP 请求 -> DispatcherServlet -> HandlerMapping -> Controller -> 业务逻辑 -> ModelAndView -> ViewResolver -> View -> 渲染 -> HTTP 响应 -> 客户端

2.1 请求处理流程核心源码解析

整个的源码很多,我这里不全部贴出来,只放出来重要的部分

在这个doDispatch方法里把处理器、处理器适配器、执行处理器方法等一系列流程都在这个方法里。比如:

  • getHandler(): 调用 HandlerMappinggetHandler() 方法,通过请求 URL 匹配到对应的 HandlerMethod(如 @RequestMapping 注解的方法)。
  • getHandlerAdapter() :遍历所有 HandlerAdapter,找到支持当前 Handler 的适配器(如 RequestMappingHandlerAdapter 处理 @Controller)。
  • Handler执行HandlerAdapterhandle() 方法通过反射执行处理器方法,期间完成参数解析(HandlerMethodArgumentResolver)和返回值处理(HandlerMethodReturnValueHandler)。
  • 视图渲染: 在 processDispatchResult() 中调用 ViewResolver 解析视图名称,最终由 View 的 render() 方法生成响应内容。

2.2 源码的扩展点

如果我们想去自定义实现一些需求,那我们就要了解整个请求处理流程的关键扩展点,那我们来看一下我们经常会用的几个扩展点:

2.2.1 HandlerMapping(处理器映射器)

常见的实现有:RequestMappingHandlerMapping(处理 @RequestMapping 注解),或者你可以自定义一个HandMapping,比如基于某种规则动态分发(比如根据请求头、请求体动态匹配)

typescript 复制代码
public class MyHandlerMapping implements HandlerMapping {
    @Override
    public HandlerExecutionChain getHandler(HttpServletRequest request) {
        // 自定义根据请求URI返回Handler
    }
}

2.2.2 HandlerAdapter(处理器适配器)

常见的实现:RequestMappingHandlerAdapter(处理基于注解的Controller),或者你自定义HandlerAdapter可以用来支持你想来支持的

2.2.3 HandlerMethodArgumentResolver(方法参数解析器)

常见的实现:我们这个知道在调用Controller方法时,负责解析方法参数,比如@RequestParam、@PathVariable。那常见的实现有**RequestParamMethodArgumentResolver**

我们可以通过此扩展点可以自己定义新的注解

另外还有返回值处理器、视图解析器、异常处理器这些都可以进行自定义扩展实现。这里就是策略模式的优点,可以在任何节点定制自己的逻辑。

3. 总结

这节的重点是,Spring MVC 的核心架构以 DispatcherServlet 为中心,通过 HandlerMappingHandlerAdapterViewResolver 等组件协同工作,实现了请求的分发、处理和响应的完整流程。

相关推荐
考虑考虑2 小时前
Mybatis实现批量插入
java·后端·mybatis
咖啡八杯3 小时前
GoF设计模式——中介者模式
java·后端·spring·设计模式
青石路7 小时前
记一次多JDK版本问题的排查,一坑套一坑,差点没爬上来
java
kyriewen7 小时前
我手写了一个 EventEmitter,面试官追问了 6 个问题——第 4 个我没答上来
前端·javascript·面试
她的男孩9 小时前
后台接口加密别只会 HTTPS,ForgeAdmin 的 RSA + SM4/AES 源码拆解
后端·面试·开源
Randyliu9 小时前
20260508-Agent搭建记录以及对ReAct框架的理解
面试·agent
像我这样帅的人丶你还10 小时前
Java 后端详解(五):Redis 缓存
java·后端·全栈
ZzT10 小时前
公司用 AI 筛简历,他写了个 AI 帮你挑公司
面试·aigc·ai编程
PBitW11 小时前
GPT训练我的第四天,被打惨了!!!😭😭😭
前端·javascript·面试
plainGeekDev12 小时前
GreenDAO → Room
android·java·kotlin