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 等组件协同工作,实现了请求的分发、处理和响应的完整流程。

相关推荐
Ray Liang1 小时前
用六边形架构与整洁架构对比是伪命题?
java·python·c#·架构设计
Sailing1 小时前
🚀 别再乱写 16px 了!CSS 单位体系已经进入“计算时代”,真正的响应式布局
前端·css·面试
Java水解1 小时前
Java 中间件:Dubbo 服务降级(Mock 机制)
java·后端
SuperEugene4 小时前
Vue状态管理扫盲篇:Vuex 到 Pinia | 为什么大家都在迁移?核心用法对比
前端·vue.js·面试
Hilaku4 小时前
我会如何考核一个在简历里大谈 AI 提效的高级前端?
前端·javascript·面试
前端Hardy4 小时前
别再用 $emit 满天飞了!Vue 3 组件通信的 4 种正确姿势,第 3 种 90% 的人不知道
前端·vue.js·面试
我叫黑大帅5 小时前
前端如何利用 GitHub Actions 自动构建并发布到 GitHub Pages?
前端·面试·github
我叫黑大帅5 小时前
前端总说的防抖与节流到底是什么?
前端·javascript·面试
掘金安东尼5 小时前
从平面到空间:用 React Three Fiber 构建 3D 产品网格
前端·javascript·面试
swipe5 小时前
#用这 9 个浏览器 API,我把页面从“卡成 PPT”救回到 90+(每个都有能直接抄的例子)
前端·javascript·面试