​ 系统架构是指整个应用系统程序的结构**[不是某一门语言特有的,是软件结构通用的]。我们平时总是将三层架构与MVC编程思想混为一谈,殊不知它俩并不是一个概念**,但是它们之间的共同点是为了降低系统模块之间的耦合度(降低耦合度可以简单理解为改动的时候不需要更改很多地方,多人参与项目可以分开写,各写个的部分,对接的时候是基于接口,内部互不影响)。

1.三层架构

我们的开发架构一般都是基于两种形式,一种是 C/S 架构,也就是客户端/服务器,另一种是 B/S 架构,也就
是浏览器服务器。在 JavaEE 开发中,几乎全都是基于 B/S 架构的开发。那么在 B/S 架构中,系统标准的三层架构
包括:表现层、业务层、持久层。三层架构在我们的实际开发中使用的非常多。
三层架构中,每一层各司其职,接下来我们就说说每层都负责哪些方面:
1.表示层/界面层 [User Interface layer]
也就是我们常说的web层。它负责接收客户端请求,向客户端响应结果,通常客户端使用http协议请求
web 层,web 需要接收 http 请求,完成 http 响应。

  • 表现层包括展示层和控制层:控制层负责接收请求,展示层负责结果的展示。
  • 表现层依赖业务层,接收到客户端请求一般会调用业务层进行业务处理,并将处理结果响应给客户端。
  • 表现层的设计一般都使用 MVC 模型。(MVC 是表现层的设计模型,和其他层没有关系)

2.业务层 [Business Logic Layer]:
也就是我们常说的 service 层。它负责业务逻辑处理,和我们开发项目的需求息息相关。web 层依赖业
务层,但是业务层不依赖 web 层。

业务层在业务处理时可能会依赖持久层,如果要对数据持久化需要保证事务一致性。(也就是我们说的,事务应该放到业务层来控制)

3.持久层 [Data access layer]:
也就是我们是常说的 dao 层。负责数据持久化,包括数据层即数据库和数据访问层,数据库是对数据进
行持久化的载体,数据访问层是业务层和持久层交互的接口,业务层需要通过数据访问层将数据持久化到数据库
中。通俗的讲,持久层就是和数据库交互,对数据库表进行曾删改查的。

在这里插入图片描述

2.MVC 编程模式

​ MVC 全名是 Model View Controller,是模型(model)-视图(view)-控制器(controller)的缩写,是一种用于设计创建 Web 应用程序表现层的模式。MVC 中每个部分各司其职:

  • Model(模型):通常指的就是我们的数据模型。作用一般情况下用于封装数据。
  • View(视图):通常指的就是我们的 jsp 或者 html。作用一般就是展示数据的。通常视图是依据模型数据创建的。
  • Controller(控制器):是应用程序中处理用户交互的部分。作用一般就是处理程序逻辑的。它相对于前两个不是很好理解,这里举个例子:

例如:
我们要保存一个用户的信息,该用户信息中包含了姓名,性别,年龄等等。
这时候表单输入要求年龄必须是 1~100 之间的整数。姓名和性别不能为空。并且把数据填充到模型之中。
此时除了 js 的校验之外,服务器端也应该有数据准确性的校验,那么校验就是控制器的该做 的。
当校验失败后,由控制器负责把错误页面展示给使用者。
如果校验成功,也是控制器负责把数据填充到模型,并且调用业务层实现完整的业务需求。

MVC工作的流程:

1.用户通过view页面向服务端提出请求,表单,超链接或者ajax请求。
2.服务器端Controller控制器接受到请求之后,对请求进行解析,找到相应的Model对请求进行处理。
3.Model处理之后,将处理的结果交回给Controller
4.Controller在接受到处理结果后,找到相应的View页面,页面经过数据渲染(填充数据)后,发给客户端。

在这里插入图片描述

3.MVC与三层架构的区别

MVC架构里面的Controller以及View层合并在一起就是三层架构的View层,而MVC的Model层就包含了三层架构的Service层以及Dao层。

在这里插入图片描述

4.SSM与三层架构的联系

SSM,即SpringMVC,Spring与Mybatis的统称。

1.SpringMVC:作为view的实现者,完成客户请求的接受功能,它的controller作为整个应用的控制器,完成用户请求的转发和对用户的响应。
2.Mybatis:作为Dao的实现者,完成数据库的增伤改查等功能。
3.Spring:是整个应用的大管家,整个应用中所有的bean的生命周期行为,都是由Spring来管理的,就是说整个应用中所有的对象的创建,初始化,销毁,以及对象之间关联的关系维护,都是由Spring来进行管理。

在这里插入图片描述

5.疑虑:MVC的定位?框架?是设计模式?是架构?

详情请参考:https://blog.csdn.net/qq_43369797/article/details/90171686

Logo

开源、云原生的融合云平台

更多推荐