SpringMvc专题

简介: SpringMvc笔记(持续更新)

SpringMvc笔记(持续更新)

SpringMvc专题

2.基于MVC模型框架之:SpringMVC


文章目录


前言

SpringMvc笔记(持续更新)

正文

1.SpringMVC 的执行过程分析

总结:

1)前端控制器DispatcherServlet 由框架提供

作用:接收请求,处理响应结果

2)处理器映射器HandlerMapping由框架提供

作用:根据请求URL,找到对应的Handler

3)处理器适配器HandlerAdapter由框架提供

作用:调用处理器(Handler|Controller)的方法

4)处理器Handler又名Controller,后端处理器

作用:接收用户请求数据,调用业务方法处理请求

5)视图解析器ViewResolver由框架提供

作用:视图解析,把逻辑视图名称解析成真正的物理视图

支持多种视图技术:JSTLView,FreeMarker…

6)视图View,程序员开发

作用:将数据展现给用户

2. SpringMVC 中三大组件详解

2.1 处理器映射器

它指的是:HandlerMapping

是在 Spring 的 3.1 版本之后加入的。它的出现,可以让使用者更加轻松的去配置 SpringMVC

的请求路径映

射。去掉了早期繁琐的 xml 的配置

它的配置有两种方式:都是在 springmvc.xml 中加入配置。

第一种方式:

<bean class="org.springframework.web.servlet.mvc.method.annotation.RequestMappingHandlerMapping"/>

第二种方式:

<mvc:annotation‐driven></mvc:annotation‐driven>

2.2 处理器适配器

要清晰的认识 SpringMVC 的处理器适配器,就先必须知道适配器以及它的作用。我们先通过下

图,直观的了

解一下:

通过上面三张图,我们可以直观的感受到,它是把不同的接口都转换成了 USB 接口。

带入到我们 SpringMVC 中,就是把不同的控制器,最终都可以看成是适配器类型,从而执行适配

器中定义的

方法。更深层次的是,我们可以把公共的功能都定义在适配器中,从而减少每种控制器中都有的重

复性代码。

学习了SpringMVC 的执行过程,最终调用的是前端控制器 DispatcherServlet 的

doDispatch 方法,而该方法中的 HandlerAdapter 的 handle 方法实际调用了我们自己写的控制

器方法。而我

们写的控制方法名称各不一样,它是通过 handle 方法反射调用的。但是我们不知道的是,其实

SpringMVC 中处

理器适配器也有多个。

HandlerAdapter详解

这里Spring mvc 采用适配器模式来适配调用指定Handler,根据Handler的不同种类采用不同的

Adapter,其Handler与 HandlerAdapter 对应关系如下:

Handler类别 对应适配器 描述

Controller SimpleControllerHandlerAdapter 标准控制器,返回ModelAndView

HttpRequestHandler HttpRequestHandlerAdapter 业务自行处理 请求,不需要通modelAnd图

Servlet SimpleServletHandlerAdapter 基于标准的servlet 处理

HandlerMethod RequestMappingHandlerAdapter 基于@requestMapping对应方法处理

第一个:org.springframework.web.servlet.mvc.SimpleControllerHandlerAdapter

使用此适配器,适用的控制器写法:要求实现 Controller 接口

1 /**
2
3 * @author 白起
4 */
5
6 public class HelloController2 implements Controller {
7
8 @Override
9 public ModelAndView handleRequest(HttpServletRequest httpServletRequest,
10
11 HttpServletResponse httpServletResponse) throws Exception {
12
13 ModelAndView mv = new ModelAndView();
14 mv.setViewName("success");
15 return mv;
16 }
17 }

同时要求我们在 springmvc.xml 中添加:

1 <bean id="simpleControllerHandlerAdapter " class="org.springframework.web.servle
t.mvc.SimpleControllerHandlerAdapter"></bean>
2 <bean name="/sayhello2" class="com.baiqi.web.controller.HelloController2">
</bean>

第二个:org.springframework.web.servlet.mvc.HttpRequestHandlerAdapter

使用此适配器的控制器写法:要求实现 HttpRequestHandler 接口

1 public class HelloController3 implements HttpRequestHandler {
2
3
4 @Override
5 public void handleRequest(HttpServletRequest request, HttpServletResponse respon
se) throws ServletException, IOException {
6 request.getRequestDispatcher("/WEB‐INF/pages/success.jsp").forward(request,resp
onse);
7 }
8 }

同时要求我们在 springmvc.xml 中添加:

1 <bean name="/sayhello3" class="com.baiqi.web.controller.HelloController3">
</bean>
2
3 <bean id=" httpRequestHandlerAdapter" class="org.springframework.web.servlet.mv
c.HttpRequestHandlerAdapter"></bean>

第三个:

org.springframework.web.servlet.mvc.method.annotation.RequestMappingHandlerAdapter

这种方式也是我们实际开发中采用最多的。它的要求是我们用注解@Controller 配置控制器

1 @Controller
2 public class HelloControler {
3
4 @RequestMapping("hello")
5 public String sayHello() {
6 System.out.println("控制器方法执行了");
7 return "success";
8 }
9 }

同时要求我们在 springmvc.xml 中配置:

1 <bean id="requestMappingHandlerAdapter" class="org.springframework.web.servlet.m
vc.method.annotation.RequestMappingHandlerAdapter"></bean>

不过通常情况下我们都是直接配置:

1 <mvc:annotation‐driven></mvc:annotation‐driven>

视图解析器我们明天再说!!!这部分的内容比较多

相关文章
|
10月前
|
物联网 程序员 芯片
你知道Hi3861芯片吗,支持OpenHarmony系统
本文介绍华为Hi3861芯片,该芯片集成了WiFi和蓝牙功能,具备低功耗、高集成度、强大通信能力和丰富接口资源,广泛应用于智能家居、智能穿戴、工业物联网和智慧城市等领域,助力开发者实现高效物联网解决方案。
492 0
你知道Hi3861芯片吗,支持OpenHarmony系统
|
存储 分布式计算 Hadoop
【赵渝强老师】HDFS数据上传和下载的过程
本文介绍了Hadoop的HDFS中客户端如何通过NameNode上传和下载数据。上传时,数据按块保存至DataNode并实现冗余;下载时,客户端从DataNode获取数据块。文中配有详细流程图及B站视频讲解。
334 3
|
机器学习/深度学习 人工智能 算法
阿里巴巴新模型EMO的技术原理
【2月更文挑战第10天】阿里巴巴新模型EMO的技术原理
1957 2
阿里巴巴新模型EMO的技术原理
|
资源调度 JavaScript 搜索推荐
Linux系统之部署CodeX Docs文档工具
【8月更文挑战第7天】Linux系统之部署CodeX Docs文档工具
377 4
|
数据采集 运维 DataWorks
DataWorks产品使用合集之跨项目克隆时,如何迁移表结构
DataWorks作为一站式的数据开发与治理平台,提供了从数据采集、清洗、开发、调度、服务化、质量监控到安全管理的全套解决方案,帮助企业构建高效、规范、安全的大数据处理体系。以下是对DataWorks产品使用合集的概述,涵盖数据处理的各个环节。
|
API 定位技术 开发工具
Android Studio2021.1.1 高德地图api调用这一篇就够了
Android Studio2021.1.1 高德地图api调用这一篇就够了
|
机器学习/深度学习 数据采集 并行计算
Matlab用深度学习长短期记忆(LSTM)神经网络对文本数据进行分类
Matlab用深度学习长短期记忆(LSTM)神经网络对文本数据进行分类
|
对象存储 存储 分布式计算
JindoFS: 云上大数据的高性能数据湖存储方案
JindoFS 是EMR打造的高性能大数据存储服务,可以为不同的计算引擎提供不同的存储服务,可以根据应用的场景来选择不同的存储模式。在2019杭州云栖大会大数据生态专场,阿里巴巴计算平台事业部EMR团队技术专家殳鑫鑫和Intel大数据团队软件开发经理徐铖共同向大家分享了云上大数据的高性能数据湖存储方案JindoFS的产生背景、架构以及与Intel DCPM的性能评测。
16897 58
JindoFS: 云上大数据的高性能数据湖存储方案
|
XML JSON JavaScript
nodejs 公众号开发攻略(包括字典码排序sha1加密代码)
nodejs 公众号开发攻略(包括字典码排序sha1加密代码)
nodejs 公众号开发攻略(包括字典码排序sha1加密代码)
|
3天前
|
云安全 人工智能 自然语言处理