WEB:有关三层架构和MVC设计模式的一些理解

文章目录

  • MVC设计模式
  • 三层架构
  • 三层架构和MVC的区别与联系

构建JavaWeb,编写代码时可能会想:一个新的类,到底该往哪个目录下的哪个文件夹里写呢?

解决办法:需要一个模式去规范

MVC设计模式

MVC设计模式不属于23种设计模式

Web MVC设计模式,用于将Web的UI层进行「职责解耦」

Web MVC标准架构如下图所示:

WEB:有关三层架构和MVC设计模式的一些理解_第1张图片
在Web MVC模式下,模型⽆法主动发送数据给视图,如果⽤户想要视图更新,需要再发送⼀次请求(即请求-响应模型)。

M:(Model) 模型 : 应⽤程序的核⼼功能,管理这个模块中⽤的数据和值(bean,dao)

从使⽤层⾯来看,JavaBean分为2⼤类:
a. 封装 业务逻辑 的JavaBean(eg:LoginDao.java 封装了登录逻辑)
b. 封装 数据 的JavaBean(实体类:eg:Student.java Vadio.java 。往往对应于数据库中的⼀张表,即数据库中有个Student表,项⽬中就有个Student.java类)通常:表名=类名,列名=属性名
JavaBean是⼀个可以重复使⽤的组件,通过编写⼀个组件来实现某种通⽤功能,“⼀次编写、任何地⽅执⾏、任何地⽅重⽤”。

V:(View)视图:视图提供模型的展示,管理模型如何显示给⽤户,它是应⽤程序的外观(jsp/html)

C:(Controller)控制器对⽤户的输⼊做出反应,管理⽤户和视图的交互,是连接模型和视图的枢纽。(servlet/service)

三层架构

通常意义上的三层架构就是将整个业务应⽤划分为:表现层(UI)、业务逻辑层(BLL)、数据访问层(DAL)。区分层次的⽬的即为了==“⾼内聚,低耦合”==的思想

  1. 表现层(UI):通俗讲就是展现给⽤户的界⾯,即⽤户在使⽤⼀个系统的时候他的所⻅所得jsp/html

  2. 业务逻辑层(BLL):针对具体问题的操作,也可以说是对数据层的操作,对数据业务逻辑处理servlet,service

  3. 数据访问层(DAL):该层所做事务直接操作数据库,针对数据的增添、删除、修改、更新、查找等dao

表现层实现的代表作品是Struts、SpringMVC框架
业务层实现的代表作品是Spring
持久层实现的代表作品是Hibernate、MyBatis

层就相当于⼀个⿊盒⼦,我们不⽤知道它内部怎么实现,只需要知道如何去调⽤它就⾏了。每层只与上下相邻的两层打交道。当⼀层内部由于技术变迁发⽣变化时,只要接⼝不变,其他层不⽤做任何改变。
分层之后灵活性提⾼,也便于团队分⼯开发。

三层架构和MVC的区别与联系

WEB:有关三层架构和MVC设计模式的一些理解_第2张图片
三层架构与MVC设计模式的区别:

三层架构 MVC设计模式
典型的架构模式(Architecture Pattern) 表现模式(Presentation Pattern)
基于业务逻辑来分层 基于⻚⾯来分
三层架构的分层模式是典型的上下关系,上层依赖于下层 相互协作关系

联系:
MVC是 Model-View-Controller,严格说这三个加起来以后才是三层架构中的UI层,也就是说,MVC把三层架构中的UI层再度进⾏了分化,分成了控制器、视图、实体三个部分,控制器完成⻚⾯逻辑,通过实体来与界⾯层完成通话;⽽M层直接与三层中的BLL进⾏对话。

你可能感兴趣的:(WEB)