写
Java Web
项⽬时会发现,⼀个中型或者⼤型项⽬ 随着代码的增多,会发现:代码既可以写在
src
⽬录下,也可以写在WebContent
⽬录下。
src
下可以建很多包 ,
WebContent
下可以建很多⽂件夹。
所以问题就来了:⼀个新的类 到底往哪个⽬录下的哪个⽂件夹⾥写?
此时解决办法就是:需要⼀个模式去规范,到底哪个类该往哪⾥写。
1.MVC设计模式
Web MVC
中的
M(
模型
)-V(
视图
)-C(
控制器
)
概念和标准
MVC
概念⼀样,我们再看⼀下
Web MVC
标准架构, 如下图所示:
M
:
(Model)
模型
:
应⽤程序的核⼼功能,管理这个模块中⽤的数据和值(
bean,dao
);(数据访问层)
V(View )
视图
:
视图提供模型的展示,管理模型如何显示给⽤户,它是应⽤程序的外观;(
jsp/html
)(表现层)
C(Controller)
控制器
: 对⽤户的输⼊做出反应,管理⽤户和视图的交互,是连接模型和视图的枢纽(
servlet/service
)(业务逻辑层)
MVC
⽤于将
web
(
UI
)层进⾏职责解耦
说明
:mvc
设计模式
(
不属于
23
种设计模式
)
2.三层架构
三层架构 通常意义上的三层架构就是将整个业务应⽤划分为:表现层(
UI
)、业务逻辑层(
BLL
)、数 据访问层(DAL
)。区分层次的⽬的即为了
“
⾼内聚,低耦合
”
的思想。
1
、表现层(
UI
):通俗讲就是展现给⽤户的界⾯,即⽤户在使⽤⼀个系统的时候他的所⻅所得。 jsp/html
2
、业务逻辑层(
BLL
):针对具体问题的操作,也可以说是对数据层的操作,对数据业务逻辑处理。 servlet,service
3
、数据访问层(
DAL
):该层所做事务直接操作数据库,针对数据的增添、删除、修改、更新、查找等。dao
表现层实现的代表作品是Struts,springmvc框架,
业务层实现的代表作品是
Spring
,
持久层实现的代表作品是
Hibernate,mybatis
。
层就相当于⼀个⿊盒⼦,我们不⽤知道它内部怎么实现,只需要知道如何去调⽤它就⾏了。每层只与上 下相邻的两层打交道。当⼀层内部由于技术变迁发⽣变化时,只要接⼝不变,其他层不⽤做任何改变。 分层之后灵活性提⾼,也便于团队分⼯开发。
3.三层架构和MVC的区别与联系
MVC
是
Model-View-Controller
,严格说这三个加起来以后才是三层架构中的
UI
层,也就是说,
MVC
把 三层架构中的UI
层再度进⾏了分化,分成了控制器、视图、实体三个部分,控制器完成⻚⾯逻辑,通过 实体来与界⾯层完成通话;⽽C
层直接与三层中的
BLL
进⾏对话。
MVC
可以是三层中的⼀个表现层框架,属于表现层。三层和
mvc
可以共存。
三层是基于业务逻辑来分的,⽽
MVC
是基于⻚⾯来分的。
MVC
主要⽤于表现层,
3
层主要⽤于体系架构,
3
层⼀般是表现层、中间层、数据层,其中表现层⼜可以分成M
、
V
、
C
,
(Model View Controller)
模型-视图-控制器
MVC
是表现模式(
Presentation Pattern
)
三层架构是典型的架构模式(
Architecture Pattern
)
三层架构的分层模式是典型的上下关系,上层依赖于下层。但
MVC
作为表现模式是不存在上下关系的, ⽽是相互协作关系。即使将MVC
当作架构模式,也不是分层模式。
MVC
和三层架构基本没有可⽐性,是应⽤于不同领域的技术
.MVC软件设计模式(和java无关)是一种分离业务逻辑和显示界面的设计方法。
三冊架构