《面试经典系列》- SpringMVC原理及工作流程
前言
SpringMVC 作为 MVC 的开源框架,现在依旧是不少项目使用的重点框架。SpringMVC = Struts2 + Spring,SpringMVC就相当于 Struts2 + Spring 的整合,SpringMVC 是 Spring 的一个后续产品,其实就是在 Spring 的原有基础上,又提供了 web 应用的 MVC 模块,可以简单地把 SpringMVC 理解为是 Spring 的一个子模块,所以可以和 Spring 进行无缝集成。
1、SpringMVC重要组件
- 前端控制器(DispatcherServlet):接收请求,响应结果,可以理解为电脑的CPU。
 - 处理器映射器(HandlerMapping):根据URL去查找处理器。
 - 处理器适配器(HandlerAdapter) :它调用后端处理器中的方法,返回逻辑视图 ModelAndView 对象。
 - 处理器(Handler):对用户具体请求进行处理,也就是程序猿编写代码处理逻辑的, 类似于Controller 类。
 - 视图解析器(ViewResovler):进行视图解析,将 ModelAndView 逻辑视图解析为具体的视图(如JSP)。
 
我把它放在一张图上,大致位置如下:

2、执行流程
我用箭头标出对应流程步骤、组件,这样有助于我们理解、记忆。
通过下图,我可以得出 SpringMVC 执行流程的大致路线。在配合组件的具体功能,就可以大致总结出 SpringMVC 的执行流程了。

SpringMVC执行流程:
1、用户发送请求至前端控制器(DisptcherServlet)。
2、 DispatcherServlet 收到请求调用处理器映射器(HandlerMapping)。
3、 处理器映射器找到具体的处理器(可以根据xml配置、注解进行查找),生成处理器对象及处理器拦截器(如果有则生成)一并返回给 DispatcherServlet。
4、 DispatcherServlet 调用处理器适配器(HandlerAdapter)。
5、 HandlerAdapter 经过适配调用具体的处理器(Controller,也叫后端控制器)。
6、 Controller 执行完成返回 ModelAndView。
7、 HandlerAdapter 将 Controller 执行结果 ModelAndView 返回给 DispatcherServlet。
8、 DispatcherServlet 将 ModelAndView 传给视图解析器(ViewReslover)。
9、 ViewReslover 解析后返回具体 View。
10、DispatcherServlet 根据 View 进行渲染视图(即将模型数据填充至视图中)。
11、 DispatcherServlet 响应用户。
3、SpringMVC组件功能介绍
1、前端控制器DispatcherServlet(不需要工程师开发),由框架提供
  作用:接收请求,响应结果,相当于转发器,中央处理器。有了dispatcherServlet减少了其它组件之间的耦合度。
  用户请求到达前端控制器,它就相当于mvc模式中的c,dispatcherServlet是整个流程控制的中心,由它调用其它组件处理用户的请求,dispatcherServlet的存在降低了组件之间的耦合性。
2、处理器映射器HandlerMapping(不需要工程师开发),由框架提供
  作用:根据请求的url查找Handler
  HandlerMapping负责根据用户请求找到Handler即处理器,springmvc提供了不同的映射器实现不同的映射方式,例如:配置文件方式,实现接口方式,注解方式等。
3、处理器适配器HandlerAdapter
  作用:按照特定规则(HandlerAdapter要求的规则)去执行Handler
  通过HandlerAdapter对处理器进行执行,这是适配器模式的应用,通过扩展适配器可以对更多类型的处理器进行执行。
4、处理器Handler(需要工程师开发)
  注意:编写Handler时按照HandlerAdapter的要求去做,这样适配器才可以去正确执行Handler
  Handler 是继DispatcherServlet前端控制器的后端控制器,在DispatcherServlet的控制下Handler对具体的用户请求进行处理。由于Handler涉及到具体的用户业务请求,所以一般情况需要工程师根据业务需求开发Handler。
5、视图解析器View resolver(不需要工程师开发),由框架提供
  作用:进行视图解析,根据逻辑视图名解析成真正的视图(view)
  View Resolver负责将处理结果生成View视图,View Resolver首先根据逻辑视图名解析成物理视图名即具体的页面地址,再生成View视图对象,最后对View进行渲染将处理结果通过页面展示给用户。springmvc框架提供了很多的View视图类型,包括:jstlView、freemarkerView、pdfView等。
  一般情况下需要通过页面标签或页面模版技术将模型数据通过页面展示给用户,需要由工程师根据业务需求开发具体的页面。
6、视图View(需要工程师开发jsp...)
View 是一个接口,实现类支持不同的View类型(jsp、freemarker、pdf...)
4、核心架构的具体流程
核心架构的具体流程步骤如下:
1、首先用户发送请求——>DispatcherServlet,前端控制器收到请求后自己不进行处理,而是委托给其他的解析器进行处理,作为统一访问点,进行全局的流程控制;
2、DispatcherServlet——>HandlerMapping, HandlerMapping 将会把请求映射为HandlerExecutionChain 对象(包含一个Handler 处理器(页面控制器)对象、多个HandlerInterceptor 拦截器)对象,通过这种策略模式,很容易添加新的映射策略;
3、DispatcherServlet——>HandlerAdapter,HandlerAdapter 将会把处理器包装为适配器,从而支持多种类型的处理器,即适配器设计模式的应用,从而很容易支持很多类型的处理器;
4、HandlerAdapter——>处理器功能处理方法的调用,HandlerAdapter 将会根据适配的结果调用真正的处理器的功能处理方法,完成功能处理;并返回一个ModelAndView 对象(包含模型数据、逻辑视图名);
5、ModelAndView的逻辑视图名——> ViewResolver, ViewResolver 将把逻辑视图名解析为具体的View,通过这种策略模式,很容易更换其他视图技术;
6、View——>渲染,View会根据传进来的Model模型数据进行渲染,此处的Model实际是一个Map数据结构,因此很容易支持其他视图技术;
7、返回控制权给DispatcherServlet,由DispatcherServlet返回响应给用户,到此一个流程结束。
小结
虽然现在市场的主流是微服务框架,但是 SpringMVC 作为 Spring 家族成员之一,且几年前得到广泛应用,现在依旧有不少的老项目在使用这个框架,所以,作为程序猿的我们,也是必须要掌握的一个框架。
《面试经典系列》- SpringMVC原理及工作流程的更多相关文章
- 第2章 rsync算法原理和工作流程分析
		
本文通过示例详细分析rsync算法原理和rsync的工作流程,是对rsync官方技术报告和官方推荐文章的解释. 以下是本文的姊妹篇: 1.rsync(一):基本命令和用法 2.rsync(二):ino ...
 - rsync算法原理和工作流程分析
		
本文通过示例详细分析rsync算法原理和rsync的工作流程,是对rsync官方技术报告和官方推荐文章的解释.本文不会介绍如何使用rsync命令(见rsync基本用法),而是详细解释它如何实现高效的增 ...
 - rsync(三)算法原理和工作流程分析
		
在开始分析算法原理之前,简单说明下rsync的增量传输功能. 假设待传输文件为A,如果目标路径下没有文件A,则rsync会直接传输文件A,如果目标路径下已存在文件A,则发送端视情况决定是否要传输文件A ...
 - 轻松理解Redux原理及工作流程
		
轻松理解Redux原理及工作流程 Redux由Dan Abramov在2015年创建的科技术语.是受2014年Facebook的Flux架构以及函数式编程语言Elm启发.很快,Redux因其简单易学体 ...
 - 【Linux高级驱动】触摸屏工作原理与工作流程
		
触摸屏工作原理 触摸屏工作流程 @成鹏致远 (blogs:http://lcw.cnblogs.com) (email:wwwlllll@126.com) ) From WizNote
 - 漫谈Github与开源,Git介绍以及Git的思想和基本工作原理 Git工作流程
		
漫谈Github与开源 文字亮点: 为什么这些优秀的工程师会开源自己的项目? 因为开源是一种精神. 无数的软件开发者苦心积虑保护自己的代码不被破解,而还是被聪明绝顶的脚本小子破解了,但破解无数软件的脚 ...
 - springmvc 运行原理   Spring ioc的实现原理   Mybatis工作流程  spring  AOP实现原理
		
SpringMVC的工作原理图: SpringMVC流程 . 用户发送请求至前端控制器DispatcherServlet. . DispatcherServlet收到请求调用HandlerMappin ...
 - Struts2的工作原理及工作流程
		
众所周知,Struts2是个非常优秀的开源框架,我们能用Struts2框架进行开发,同时能 快速搭建好一个Struts2框架,但我们是否能把Struts2框架的工作原理用语言表达清楚,你表达的原理不需 ...
 - 【关于selenium自动化中,Webdriver的原理以及工作流程】
		
原文地址:https://www.cnblogs.com/imyalost/p/7242747.html#4109245 作者:老 张 1.关于Webdriver 设计模式:按照Server-Clie ...
 
随机推荐
- .Net Core 实现图片验证码
			
记录自己的学习,参考了网上各位大佬的技术,往往在登录的时候需要使用到验证码来进行简单的一个校验,这边使用在.net core上进行生成图片二维码 思路很简单=> 生成一个随机数->保存到服 ...
 - kafka使用指南
			
快速开始 本教程假设您刚刚开始,并且没有现有的Kafka或ZooKeeper数据.由于Kafka控制台脚本对于基于Unix和Windows的平台是不同的,因此在Windows平台上使用bin\wind ...
 - Python第一周作业
			
import turtle turtle.color('black','red') turtle.pensize(10) turtle.begin_fill() for i in range(5): ...
 - docker安装mysql主从
			
docker安装mysql主从 启动主库: 1.docker run --name master -p 3306:3306 -e MYSQL_ROOT_PASSWORD=root -d mysql:5 ...
 - hdu1171kmp果题
			
题目链接:http://icpc.njust.edu.cn/Problem/Hdu/1711/ #include<bits/stdc++.h> using namespace std; t ...
 - 【分布式锁】06-Zookeeper实现分布式锁:可重入锁源码分析
			
前言 前面已经讲解了Redis的客户端Redission是怎么实现分布式锁的,大多都深入到源码级别. 在分布式系统中,常见的分布式锁实现方案还有Zookeeper,接下来会深入研究Zookeeper是 ...
 - 在TensorFlow中实现文本分类的卷积神经网络
			
在TensorFlow中实现文本分类的卷积神经网络 Github提供了完整的代码: https://github.com/dennybritz/cnn-text-classification-tf 在 ...
 - 软件架构的演进:单体、垂直、SOA、微服务
			
软件架构演进 软件架构的发展经历了从单体结构.垂直架构.SOA架构到微服务架构的过程,以下为具体分类: 1.1.1 单体架构 特点: 1.所有的功能集成在一个项目工程中. 2.所有的功能打一 ...
 - django中 对Mysql数据库的建表
			
Django操作Mysql数据库: 1.1 在settings中,配置数据库相关参数,所以无需修改,这里我们看一下: DATABASES = { 'default': { # 这里可以指定使用的数据库 ...
 - Openresty+Lua+Kafka实现日志实时采集
			
简介 在很多数据采集场景下,Flume作为一个高性能采集日志的工具,相信大家都知道它.许多人想起Flume这个组件能联想到的大多数都是Flume跟Kafka相结合进行日志的采集,这种方案有很多他的优点 ...