博客
关于我
SpringMVC初认识
阅读量:271 次
发布时间:2019-03-01

本文共 1292 字,大约阅读时间需要 4 分钟。

SpringMVC初认识

1.什么是MVC

​ a.MVC是模型(Model)、视图(View )、控制器(Controller)的简写,是一种软件设计规范。

​ b.是将业务逻辑、数据、显示分离的方法来组织代码

​ c.MVC主要作用是降低了视图与业务逻辑间的双向耦合

​ d.MVC不仅仅是一种设计模式,更是一种架构模式

2.第一个SpringMVC程序

​ a.新建一个Moudle,添加web支持

​ b.写一个视图 test.jsp 显示数据${msg}

​ c.确定导入了SpringMVC的依赖,以及在lib文件夹中的依赖

​ d.在web.xml中配置DispatcherServlet:这个是SpringMVC的核心:请求分发器,前端控制器

​ e.编写SpringMVC的配置文件:springmvc-servlet.xml (名称按照官方规定)

​ f.在配置文件中 添加处理器映射器、处理器适配器和视图解析器(SpringMVC核心三要素)

​ g.Controller层实现业务代码和视图跳转

2.1 SpringMVC的优点

  • 可以支持各种视图技术,而不仅仅局限于JSP;

  • 与Spring框架集成(如IoC容器、AOP等);

  • 清晰的角色分配:前端控制器(dispatcherServlet) , 请求到处理器映射(handlerMapping), 处理器适配器(HandlerAdapter), 视图解析器(ViewResolver)。

  • 支持各种请求资源的映射策略。

3.SpringMVC执行流程

​ a.DispatcherServlet表示前置控制器,是整个SpringMVC的控制中心,接受用户发出的请求并拦截

​ 假设请求的url为:http://localhost://8080/SpringMVC/hello

​ 其中:http://localhost:8080 为服务器域名

​ SpringMVC为部署在服务器上的web站点

​ hello表示控制器

​ 如上的url表示请求位于服务器localhost:8080上的SpringMVC站点的hello控制器

​ b.HandlerMapping表示处理器映射,DispatcherServlet自己调用

​ HandlerMapping根据请求url去寻找Handler

​ c.HandlerExecution表示具体的Handler,其主要作用是根据url寻找具体的控制器,在上面的例子中控制器是hello,

​ d.HandlerExecution将解析后的信息返回给DispatcherServlet

​ e.HandlerAdapter表示处理器适配器,其按照特定规则去执行Handler(就是去寻找Controller)

​ f.Controller将具体的执行信息返回给HandlerAdapter,比如:ModelAndView

​ g.DispatcharServlet调用视图解析器(ViewResolver)解析HandlerAdapter传递的逻辑视图名

​ h.DispatcharServlet根据视图解析器解析的视图结果,调用具体视图

​ i.最终视图呈现给用户

转载地址:http://fyox.baihongyu.com/

你可能感兴趣的文章
MySQL索引底层:B+树详解
查看>>
Mysql索引总结
查看>>
mysql索引最左匹配原则理解以及常见的sql使用的索引情况的实测
查看>>
Mysql索引类型
查看>>
MySQL索引背后的数据结构及算法原理
查看>>
mysql索引能重复吗_mysql “索引”能重复吗?“唯一索引”与“索引”区别是什么?...
查看>>
Mysql索引(2):索引结构
查看>>
Mysql索引(4):索引语法
查看>>
mysql级联删除_Mysql笔记系列,DQL基础复习,Mysql的约束与范式
查看>>
mysql经常使用命令
查看>>
MySQL经常使用技巧
查看>>
mysql给账号授权相关功能 | 表、视图等
查看>>
MySQL缓存使用率超过80%的解决方法
查看>>
Mysql缓存调优的基本知识(附Demo)
查看>>
mysql网站打开慢问题排查&数据库优化
查看>>
mysql网络部分代码
查看>>
mysql联合索引的最左前缀匹配原则
查看>>
mysql自动化同步校验_Shell: 分享MySQL数据同步+主从复制自动化脚本_20190313_七侠镇莫尛貝...
查看>>
mysql自增id超大问题查询
查看>>
MySQL自带information_schema数据库使用
查看>>