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到的客户端;

四、详细源码请求流程

相关推荐
howard20054 小时前
Hive实战任务 - 9.3 实现学生信息排序和统计
hive·排序·汇总·学生信息
番茄撒旦在上4 小时前
什么样的表适合做拉链表
大数据·数据仓库·hive
YMatrix 官方技术社区4 小时前
YMatrix 高可用详解:3 种镜像策略在节点宕机时表现有何不同?
运维·数据库·数据仓库·ai·数据库开发·数据库架构·ymatrix
howard20055 小时前
Hive实战任务 - 9.5 实现网址去重
hive·网址去重
howard20055 小时前
Hive实战任务 - 9.4 分科汇总求月考平均分
hive·分科汇总月考平均分
howard20056 小时前
Hive实战任务 - 9.2 统计总分与平均分
hive·统计总分与平均分
zhixingheyi_tian9 小时前
Hadoop 之 ENV
大数据·hadoop·分布式
小鹿学程序9 小时前
任务一- 2.子任务二:Hadoop完全分布式安装配置
大数据·hadoop·分布式
yumgpkpm1 天前
Iceberg在Cloudera CDP集群详细操作步骤
大数据·人工智能·hive·zookeeper·spark·开源·cloudera