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

相关推荐
kangkang-7 分钟前
PC端基于SpringBoot架构控制无人机(三):系统架构设计
java·架构·无人机
界面开发小八哥2 小时前
「Java EE开发指南」如何用MyEclipse创建一个WEB项目?(三)
java·ide·java-ee·myeclipse
yanlele2 小时前
我用爬虫抓取了 25 年 5 月掘金热门面试文章
前端·javascript·面试
idolyXyz2 小时前
[java: Cleaner]-一文述之
java
一碗谦谦粉2 小时前
Maven 依赖调解的两大原则
java·maven
netyeaxi3 小时前
Java:使用spring-boot + mybatis如何打印SQL日志?
java·spring·mybatis
收破烂的小熊猫~3 小时前
《Java修仙传:从凡胎到码帝》第四章:设计模式破万法
java·开发语言·设计模式
猴哥源码3 小时前
基于Java+SpringBoot的动物领养平台
java·spring boot
老任与码3 小时前
Spring AI Alibaba(1)——基本使用
java·人工智能·后端·springaialibaba
小兵张健3 小时前
武汉拿下 23k offer 经历
java·面试·ai编程