SpringMvc执行流程源码解析

一、简介

Spring web Mvc是基于ServletApi构建的原始Web模块,从一开始就包含在Spring框架中;

从Servlet到SpringMvc

最典型的MVc就是JSP+Servlet+javaBean的模式;

弊端:

1、xml下配置Servlet的映射非常麻烦,效率低;

2、必须要继承父类,重写方法侵入性强;

3、如果想在一个Servlet中处理同一个业务模块的功能分发给不同的方法进行处理非常麻烦;

4、参数解析麻烦;单个参数->pojo对象,Json文本->pojo对象;

5、数据响应麻烦;pojo->json

6、跳转页面麻烦,对path控制;

所以SpringMVC就是在Servlet的基础上进行了封装;

二、Mvcweb开发的实现方式

1、 给Servlet容器配置一个DispatcherServlet(web.xml )

2、 添加SpringMVC的配置信息

继承类/实现接口方式:

复制代码
implements HttpRequestHandler
implements Controller

不同的HandlerMapping:

复制代码
<!‐‐通过设置属性的方式去设置映射路径‐‐>
<bean class="org.springframework.web.servlet.handler.SimpleUrlHandlerMapping">
<property name="mappings">
<props>
<prop key="httpRequest">simpleController</prop>
</props>
</property>

<!‐‐BeanNameUrlHandlerMapping 一定要为Controller设置一个有效映射地址的名字 如 @Con
troller("/xxxx")‐‐>
<bean
class="org.springframework.web.servlet.handler.BeanNameUrlHandlerMapping"/>

注解方式:配置控制器@Controller和处理方法的映射---@RequstMapping 即可

原理:说白了就是用一个DispatcherServlet 封装了一个Servlet的调度中心, 由调度中心帮我们调用我们的处理方法:在这个过程中调度中心委托给各个组件执行具体工作 ,比如帮我们映射方法请求、帮我解析参数、调用处理方法、响应数据和页面 等

三、SpringMvc的具体执行流程

中央Servlet DispatcherServlet为请求处理流程提供统一调度,实际工作交给可配置组件执行;

DispatcherServlet:前端调度器,负责将请求拦截下来分发给各控制方法中;

HandlerMapping: 处理器映射器,负责根据请求的URL和配置@RequestMapping映射去匹配, 匹配到会返回Handler;

HandlerAdaper: 处理器适配器,负责调用Handler-具体的方法- 返回视图的名字 Handler将它封装到ModelAndView;

ViewReslover:视图解析器, 根据ModelAndView里面的视图名地址去找到具体的jsp封装在View对象中;

View:进行视图渲染(将jsp转换成html内容 --这是Servlet容器的事情了) 最终response到的客户端;

四、详细源码请求流程

相关推荐
chad__chang7 小时前
dolphinscheduler安装过程
hive·hadoop
莫叫石榴姐14 小时前
字节数开一面
大数据·数据仓库·职场和发展
ajax_beijing17 小时前
hadoop的三副本数据冗余策略
大数据·hadoop·分布式
weixin_307779131 天前
在 Microsoft Azure 上部署 ClickHouse 数据仓库:托管服务与自行部署的全面指南
开发语言·数据库·数据仓库·云计算·azure
weixin_307779131 天前
AWS Redshift 数据仓库完整配置与自动化管理指南
开发语言·数据仓库·python·云计算·aws
yumgpkpm2 天前
CMP (类ClouderaCDP7.3(404次编译) )华为鲲鹏Aarch64(ARM)信创环境多个mysql数据库汇聚的操作指南
大数据·hive·hadoop·zookeeper·big data·cloudera
华阙之梦2 天前
【在 Windows 上运行 Apache Hadoop 或 Spark/GeoTrellis 涉及 HDFS 】
hadoop·windows·apache
还是大剑师兰特2 天前
Hadoop面试题及详细答案 110题 (96-105)-- Hadoop性能优化
hadoop·大剑师·hadoop面试题
ApacheSeaTunnel2 天前
新兴数据湖仓手册·从分层架构到数据湖仓架构(2025):数据仓库分层的概念与设计
大数据·数据仓库·开源·数据湖·dataops·白鲸开源·底层技术