声明:本栏目所使用的素材都是凯哥学堂VIP学员所写,学员有权匿名,对文章有最终解释权;凯哥学堂旨在促进VIP学员互相学习的基础上公开笔记。
三层架构模式介绍
三层架构模式:
三层架构(3-tier architecture) 通常意义上的三层架构就是将整个业务应用划分为:界面层(User Interface layer)、业务逻辑层(Business Logic Layer)、数据访问层(Data access layer)。区分层次的目的即为了 “高内聚低耦合” 的思想。在软件体系架构设计中,分层式结构是最常见,也是最重要的一种结构。微软推荐的分层式结构一般分为三层,从下至上分别为:数据访问层、业务逻辑层(又或称为领域层)、表示层。
表示层:
界面层也称为表示层,位于最外层(最上层),离用户最近。用于显示数据和接收用户输入的数据,为用户提供一种交互式操作的界面。
业务逻辑层:
业务逻辑层(Business Logic Layer)无疑是系统架构中体现核心价值的部分。它的关注点主要集中在业务规则的制定、业务流程的实现等与业务需求有关的系统设计,也即是说它是与系统所应对的领域(Domain)逻辑有关,很多时候,也将业务逻辑层称为领域层。例如Martin Fowler在《Patterns of Enterprise Application Architecture》一书中,将整个架构分为三个主要的层:表示层、领域层和数据源层。作为领域驱动设计的先驱Eric Evans,对业务逻辑层作了更细致地划分,细分为应用层与领域层,通过分层进一步将领域逻辑与领域逻辑的解决方案分离。 业务逻辑层在体系架构中的位置很关键,它处于数据访问层与表示层中间,起到了数据交换中承上启下的作用。由于层是一种弱耦合结构,层与层之间的依赖是向下的,底层对于上层而言是“无知”的,改变上层的设计对于其调用的底层而言没有任何影响。如果在分层设计时,遵循了面向接口设计的思想,那么这种向下的依赖也应该是一种弱依赖关系。因而在不改变接口定义的前提下,理想的分层式架构,应该是一个支持可抽取、可替换的“抽屉”式架构。正因为如此,业务逻辑层的设计对于一个支持可扩展的架构尤为关键,因为它扮演了两个不同的角色。对于数据访问层而言,它是调用者;对于表示层而言,它却是被调用者。依赖与被依赖的关系都纠结在业务逻辑层上,如何实现依赖关系的解耦,则是除了实现业务逻辑之外留给设计师的任务。
数据访问层:
数据访问层,有时候也称为是持久层,其功能主要是负责数据库的访问,可以访问数据库系统、二进制文件、文本文档或是XML文档。简单的说法就是实现对数据表的select、insert、update以及delete的操作。如果要加入ORM的元素,那么就会包括对象和数据表之间的mapping,以及对象实体的持久化。
三层与MVC的区别:
很多人容易把三层模式与MVC模式混淆,三层与MVC的最不同的地方在于三层是没有Controller控制器的概念。虽然同样是架构级别的,三层与MVC相同的地方在于他们都有一个表现层,但是他们不同的地方在于其他的两个层。MVC没有把业务的逻辑访问看成两个层,这是采用三层架构或MVC搭建程序最主要的区别。当然了,在三层中也提到了Model概念,但是三层架构中Model的概念与MVC中Model的概念是不一样的,“三层” 中典型的Model层是以实体类构成的,而MVC里,则是由业务逻辑与访问数据组成的。
在三层中JSP与Servlet代码都属于表示层,业务逻辑层则是完成业务规则的实体类,数据访问层则是JDBC等代码,示意图:
三层架构把不同层的业务职责分离得更加彻底,逻辑层不包含一丁点的视图层代码,同样的数据层也不应该包含一丁点的逻辑层代码,因为如果包含了其他层的代码就不能做到完全解耦,依旧存在一定程度的耦合性。
三层架构更好的实现了模块化编程,使用三层架构设计的系统更容易扩展、更换,特别是如今不止pc端一种设备,如果没做好分层就无法适应多设备的访问。例如表示层我们使用jsp+Servlet做的,面向的是web,如果哪天不做web了,要把整个表示层更换成桌面的图形化来显示,那么使用了三层架构的话,只需要更换表示层即可,逻辑层和数据层都可以进行复用。如果没有进行分层的话,各个模块都耦合在一起就无法进行复用,只能重新再编写一个适应桌面的系统出来,这样就很耗时耗力了。
我们都知道WebService是一种跨编程语言和跨操作系统平台的远程调用技术,如果一个系统是使用三层架构进行设计的,那么逻辑层就可以通过WebService共享给其他不同语言编写的应用程序调用。
最近流行的微信小程序是通过https访问服务器的,它需要服务器返回json数据,那么我们就可以在视图层中的Servlet接收这个访问,处理完成后返回json数据。
示意图:
三层开发模式的优缺点
优点:
1、开发人员可以只关注整个结构中的其中某一层;
2、可以很容易的用新的实现来替换原有层次的实现;
3、可以降低层与层之间的依赖;
4、有利于标准化;
5、利于各层逻辑的复用。
6、结构更加的明确
7、在后期维护的时候,极大地降低了维护成本和维护时间
缺点:
1、降低了系统的性能。这是不言而喻的。如果不采用分层式结构,很多业务可以直接造访数据库,以此获取相应的数据,如今却必须通过中间层来完成。
2、有时会导致级联的修改。这种修改尤其体现在自上而下的方向。如果在表示层中需要增加一个功能,为保证其设计符合分层式结构,可能需要在相应的业务逻辑层和数据访问层中都增加相应的代码。
比如,一家饭店添加了一样菜, 那个菜单(UI) , 厨师(BLL) , 采购(DAL) 都要进行相应的处理
相关推荐
1. **JavaEE架构**:JavaEE平台提供了丰富的API和服务,支持多层架构,包括表现层(Presentation Layer)、业务逻辑层(Business Logic Layer)和数据访问层(Data Access Layer)。在线打车系统可能利用这些层进行...
详解JAVAEE——SSH三大框架整合(spring+struts2+hibernate) 知识点一:SSH三大框架整合概述 SSH三大框架整合是指将Spring、Struts2和Hibernate三个框架进行整合,以便于在JAVAEE项目中实现复杂的业务逻辑。这种...
### JavaEE多层架构Struts2+Spring3+Hibernate3+Ajax的整合 #### 概述 随着软件开发技术的不断进步,构建可复用、易于扩展并经过良好测试的软件组件变得尤为重要。在此背景下,Struts、Spring 和 Hibernate 这三大...
本主题将深入探讨JavaEE系统架构中的持久化层、面向对象编程以及工作流,同时结合实际案例——企业主流MySQL高可用集群架构三部曲之PXC,来增强理解。 首先,JavaEE的持久化层是处理数据库交互的核心部分。它通过...
3. **三层架构模式(Model2:MVC)**: - **含义**:引入了 Servlet 控制器,它负责处理用户的请求并调用相应的 JavaBean 来执行业务逻辑,最终将结果返回给 JSP 页面。 - **优缺点**: - **优点**:明确地划分了...
在JavaEE世界中,三大核心框架——Struts、Hibernate和Spring,被誉为"SSH",它们各自解决了不同层面的问题,共同构建了一个强大的开发框架体系。 **Struts框架**: Struts是一个开源的MVC(Model-View-Controller...
本系统——"基于JavaEE的商城系统",便是利用JavaEE的核心技术,结合数据库管理和第三方服务,构建了一个完整的手机商城应用。本文将深入解析该系统的开发技术与实现细节。 首先,系统采用了经典的MVC(Model-View-...
JavaEE(Java Platform, Enterprise Edition)是Oracle公司提供的一个用于开发企业级应用的软件平台,它基于Java语言,为构建分布式、多层架构的应用提供了全面的框架和技术支持。这个课件可能包含了一系列关于...
【描述】"MyEclipse6JavaEEDev Spring Hibernate Struts"描述了这个主题的核心内容,即在MyEclipse6中进行JavaEE开发时,主要涉及的三个框架——Spring、Hibernate和Struts。Spring是一个全面的后端开发框架,提供...
JavaEE程序设计通常涉及到Web应用程序的开发,特别是利用三大框架——Struts、Hibernate和Spring进行企业级应用的构建。这三大框架是JavaEE领域中非常关键的组件,它们各自负责不同的职责,共同协作以实现高效、灵活...
这份文档名为《Java EE 框架整合开发入门到实战——Spring+Spring MVC+MyBatis(微课版)课后习题答案.pdf》,它显然是关于Java EE中流行的三个框架整合使用的教程。这三个框架分别是Spring、Spring MVC和MyBatis,...
- **用户角色与权限**:系统设计了三种不同的用户角色——学生、教师和系统管理员,每种角色拥有不同的操作权限。例如,学生只能查看个人信息和成绩,教师则可以管理课程信息和录入成绩,而系统管理员则负责整个系统...
SSM框架是Java EE开发中常用的三大框架——Spring、Spring MVC和MyBatis的组合,它们各自负责不同的职责,共同构建了一个强大的企业级应用开发体系。以下是对这些框架的详细解释: 1. **Spring框架**:Spring是Java...
系统架构通常遵循MVC(Model-View-Controller)设计模式,它将应用程序分为三个核心组件,以实现功能模块化,提高应用的可维护性和可扩展性。 JavaEE系统基于B/S(Browser/Server)结构,即浏览器/服务器结构,这是...
这不仅加深了对JavaEE架构的理解,也锻炼了实际开发能力。 3.2 体会 在这个过程中,我们认识到框架的选择和集成对于项目开发的重要性,同时也体验到了团队合作的力量。Struts2提供了灵活的请求处理,Spring简化了...
在系统设计上,我们可以看到经典的三层架构模式的运用:表现层(Presentation Layer)、业务逻辑层(Business Logic Layer)和数据访问层(Data Access Layer)。表现层主要由前端界面组成,负责用户交互;业务逻辑...
这种三层架构模式使得各层职责明确,降低了组件间的耦合度,提高了代码的可测试性和可扩展性。 本书会详细讲解如何配置和使用这三大框架,从搭建环境到创建项目,从设计模型到实现业务逻辑,再到持久化数据,每一个...
这个项目采用的是典型的三层架构——表现层(BUI)、业务逻辑层(Business)和服务数据访问层(Service/DAO),并且与SQL Server数据库相结合,为用户提供高效、交互性强的在线讨论环境。 1. **JavaEE技术**:...
3. **架构设计**:可能采用三层架构,包括表现层(使用JSP或JSF)、业务逻辑层(EJB或Spring Bean)、数据访问层(JDBC或Hibernate)。也可能引入MVC(Model-View-Controller)设计模式,提高代码的可维护性和可扩展...
根据给定文件的信息,我们可以提炼出...综上所述,通过韩顺平老师的JavaEE全套教程第15部分——《Struts2基础入门》的学习,你可以系统地掌握Struts2框架的基本原理和开发技巧,为后续的Web应用开发打下坚实的基础。