百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 文章教程 > 正文

源码精读 - Spring MVC - 介绍(一)

yund56 2025-04-29 00:57 25 浏览

提到SpringMVC大家也许很快会想到它的使用,它的原理,大部分的认知还来自于图书,本文将区别于传统的图书,从精读Spring MVC源码入手,学习其设计精髓,从而将其底层理论运用到实际的架构设计工作中,更有甚者可以自己写一套基于MVC理论的后端框架

前提

SpringMVC版本:spring-webmvc-5.3.7

之所以选用这个版本,是因为在作者实际工作中,这个版本用到的最多。

根目录

org.springframework.web.servlet

从目录结构上,我们不难发现该模块属于SpringFramework框架,区别于如SpringBoot, SpringCloud, web目录表示其主要包含web相关的内容,看到servlet目录大家最容易想到的肯定是J2EE,是的没错,该框架主要就是对Servlet的封装与集成,其目的是为了快速高效并方便的使用Servlet。

让我们来看下官方的注释

org.springframework.web.servlet.package-info

上类中的原文是:


官方源码DOC精读时刻

原文:Provides servlets that integrate with the application context infrastructure, and the core interfaces and classes for the Spring web MVC framework.

中文:提供了与应用程序上下文基础架构集成的 Servlet,并且提供了Spring Web MVC 框架的核心接口和类型。


原文:This package and related packages are discussed in Chapters 12 and 13 of Expert One-On-One J2EE Design and Development by Rod Johnson (Wrox, 2002).

中文:此软件包和相关软件包在一起 Rod Johnson 的 Expert One-On-One J2EE 设计和开发(Wrox,2002 年)的第 12 章和第 13 章中进行了讨论。

上述doc中,我们了解到了如:

Expert One-On-One J2EE Design and Development 是一本图书,其作者为Rod Johnson,出版社Wrox

Wrox公司简介

Wrox公司是以“由程序员为程序员而著”为创作理念的著名出版公司。在这种理念的指导下,Wrox出版了几百本深受全世界程序员青睐的优秀编程类图书,内容涉及C、C++、PHP、Oracle、SQLServer、Java、.NET等各个主要的计算机程序开发领域,曾指引数以百万计的计算机编程爱好者迅速踏进编程殿堂,并帮助无数初中级开发人员成为开发高手。

从上述描述中我们不难发现,这个包的程序应为为SpringMVC的核心,其中主要包含了如下内容:

从上述类图中我们不难发现,其核心内容如下:

FlashMap: 用于保存一个URL跳向另一个URL时的属性

FlashMapManager:重定向FlashMap管理器,定义了从上一个请求中获取并更新FlashMap的方法及并输出FlashMap

ThemeResolver:主题解析器,关于主题的解析提供了基于Cookie与基于Session的解决方案,

用户可以通过修改固定的key并结合HandlerInterceptor拦截器来修改主题,是动态主题切换的一个解决方案

HandlerInterceptor: 用于自定义处理程序执行链工作流接口。应用程序可以某些处理程序注册任意数量的现有或自定义拦截器以添加常见的预处理行为,而无需修改每个处理程序实现。

AsyncHandlerInterceptor: 是对HandlerInterceptor的扩展,包含了开始异步请求处理后调用的回调方法 。

HandlerMapping:用于定义请求与处理对象间的映射的接口,主要定义了通过请求转换为请求处理链的方法

HandlerAdapter: MVC 框架 SPI(SPI ,全称为 Service Provider Interface,是一种服务发现机制。它通过在ClassPath路径下的META-INF/services文件夹查找文件,自动加载文件里所定义的类),允许核心 MVC 工作流的参数化.

HandlerExecutionChain:处理器执行链,包括了处理程序对象和任何处理程序拦截器。由 HandlerMapping 的 HandlerMapping.getHandler 方法返回。

HandlerExceptionResolver: 解决执行期间异常处理的解析器

LocaleResolver:基于 Web 的区域设置解析策略的接口

LocaleContextResolver:是对LocaleResolver的扩展,添加了支持富有的Locale的上下文

ViewResolver:视图解析器,可以按名称解析视图的对象实现的接口

View:视图,用于 Web 交互的 MVC 视图,用于呈现内容并暴露模型。

HttpServletBean:是HttpServlet的扩展,它将其配置参数(web.xml 中的 servlet 标记内的 init-param 条目)视为 bean 属性

SmartView:提供了附加的信息,比如一个视图是否是重定向的。


RequestToViewNameTranslator
:请求转为视图名的翻译器

FrameworkServlet:Spring Web 框架的基本 servlet。在基于 JavaBean 的整体解决方案中提供与 Spring 应用程序上下文的集成

DispatcherServlet:HTTP 请求或处理程序控制器的中央调度程序,如WebUI的控制器或基于http协议远程服务输出,将一个web请求分发给注册的处理器


ModelAndViewDefiningException:
模型与视图定义异常,可以将发生错误时抛出的异常发送个一个特定模型的特定的视图

NoHandlerFoundException:默认情况下,当 DispatcherServlet 找不到请求的处理程序时,它会发送 404 响应。但是,如果其属性“
throwExceptionIfNoHandlerFound”设置为 true,则会引发此异常,并且可以使用配置的 HandlerExceptionResolver 进行处理。

ModelAndView: Web MVC 框架中模型和视图的持有者。请注意,模型与视图是完全不同的。此类仅仅持有两者以使控制器可以在单个返回值中返回模型和视图。


DispatcherServlet.properties:
定义了DispatcherServlet 的策略接口的默认实现类

至此,我们已经把Spring MVC的核心框架类进行简单的介绍与认识,其无非也是对MVC理论知识的抽象与定义,让我们用一个脑图来表达下其核心吧。


接下来,我们将会从具体的实现为切入点,详细的介绍各部分内容,尽情期待。

相关推荐

Frequency函数用法详解—6个示例

Hello,大家好!今天和大家分享Frequency函数的使用方法。Frequency函数可以用于统计数据的频率分布,其语法为frequency(data_array,bins_array)。其中参数...

期刊论文网:查重复值excel的函数

问:如何在excel表格中用公式查找重复值答:打开需要查找重复值的excel表格,找到需要查找的A列。2、将鼠标定位在C1单元格中,在编辑栏中输入公式“=IF(COUNTIF($A:$A,A1)>...

MATCH 函数的几个典型应用

MATCH函数,用于在一行或一列的查询区域中搜索指定内容,然后返回该内容在查询区域中的相对位置。MATCH函数有三个参数,第一个参数是查找对象,第二参数指定查找的范围,第三参数用数字来指定匹配方式...

LOOKUP+INDIRECT组合封神!合并单元格查询从此无压力!

你是不是经常遇到这样的问题?“A列部门是合并单元格,B列是员工姓名,怎么根据姓名快速查部门?”手动翻找?眼睛看花!用VLOOKUP直接查?合并单元格全是坑!今天教你一个神级公式,用LOOKUP+IN...

Match函数的使用方法

一、Match函数。功能:返回符合特定值特定顺序的项在数组中的相对位置。语法结构:=Match(查询值,数据范围,[匹配方式])。其中“匹配方式”有三种,分别为:-1(大于)、0(精准匹配)、1(小于...

两个表格如何匹配出相同的数据!用一个表查询另一个表进行填充!

Excel秘籍大全,前言两个表格匹配出相同的数据,可以通过匹配数据然后复制粘贴即可。当然,也可以直接使用VLOOKUP函数或者INDEX和MATCH函数组合来实现。具体使用哪种方法,可以根据自身需求来...

INDEX+MATCH函数一组合,赛过VLOOKUP函数

提到查询数据,首先想到的就是VLOOKUP函数。但VLOOKUP查询有两个不便之处:1、查找值(第一个参数)始终位于查找区域(第二个参数)的第一列;2、从左向右查找容易,但从右向左查找需要IF或CHO...

Excel模糊查找学会这5个方法,工作简直开了挂

模糊查找向来都是一个比较难的点,即使你对VLOOKUP、LOOKUP函数很熟悉,但有些问题也是要想很久。但当你学会下面这5个方法时,工作简直跟开了挂一样!下图中,我们想要通过E列的姓名在B:C表数据区...

PART19:MATCH+HLOOKUP查找匹配直接套用!

公式解析HLOOKUP:在表格或数值数组的首行查找指定的数值,并由此返回表格或数组当前列中指定行处的数值。(默认情况下,表是升序的)数据表的首行必须为查找值所在行FALSE-精确匹配TRUE-近似匹配...

拒绝加班!快速完成Excel表格核对重复数据!

如何快速完成两个表格或者两组数据对比工作,在日常工作中非常重要,你用的是哪一种方法?平凡的世界平凡的你,努力学习使我们变得不平凡,今天要介绍的知识是excel核对表格差异的相关知识,你准备好学习exc...

如何筛选两个电子表格中重复的数据

#如何筛选两个电子表格中重复的数据#在Excel中筛选两个电子表格中的重复数据,可以通过多种方法实现。以下是几种常用的方法,以及它们的操作步骤:方法一:使用条件格式突出显示重复项打开Excel,并加载...

Excel-函数技巧,COUNTIF+MATCH+INDEX提取不重复物料

要求:用函数求出B列当中,不重复的物料,也就是物料的唯一值。函数公式如下:{=IFERROR(INDEX($B$3:$B$142,MATCH(0,COUNTIF($G$2:G2,$B$3:$B$142...

excel如何快速提取不重复值?提供2个经典用法

当excel有很多数据,而且有很多是重复数据的时候,如何快速提取不重复值就成为了需要解决的难题!如图中案例,A列是学校的列表,由于很多学员都出自同一所大学,所以就会有很多重复的。现在,需要提取不重复的...

如何根据多个条件查找数据,我整理了三种方法

一、案例如下图所示,A1:C8为某小区住户信息表,要求根据楼栋和房号查询住户姓名。二、解决方法方法一、INDEX+MATCH函数在G2单元格输入公式=INDEX($C$2:$C$8,MATCH(1,(...

利用match函数让两个表格排序一致

利用match函数让两个表格排序一致一线老师经常统计学生的情况,有时两个不同的表格由于姓名顺序不一致,手动调整往往需要耗费大量的时间与精力,当我们需要将两个表格的数据需要按照相同的顺序进行对比时,我们...