`
孤星119
  • 浏览: 124648 次
  • 性别: Icon_minigender_1
  • 来自: 杭州
社区版块
存档分类
最新评论

Web应用分层及其各层职责

 
阅读更多
                                                                                              转载 原文地址 http://noia-zhou.iteye.com/blog/486037

应用层

    许多设计良好的web应用,可以被按职责分为四层。这些层次是表现层、持久层、业务层、和领域模型层。每一个层次都有其独特的职责,不能把各自的功能与其它层次相混合。每一个应用层都应该和其它层隔离开来,但允许使用接口在层间进行通信。我们开始来看看每个层,并讨论一下它们各自都应该提供什么和不应该提供什么。

表现层

    一个典型的web 应用的末端是表现层。许多Java 开发者都知道Struts提供了什么东西。然而,太多时候,耦合代码比如业务逻辑被放进org.apache.struts.Action中。所以,我们先总结一下Struts之类的框架应该提供什么。下面就是Struts 的职责所在:

   1. 管理用户的请求和响应
   2. 提供一个控制起来将调用委托到业务逻辑和其他上游处理
   3. 将来自于抛出例外的其他层的例外处理到Struts Action 中
   4. 组装可以在视图中表现的模型对象
   5. 执行UI 校验

下面是一些经常可以使用Struts进行编码但是不应该和表现层关联的事情:

   1. 直接和数据库交互,比如JDBC 调用
   2. 与应用相关的业务逻辑和校验
   3. 事务管理

在表现层中引入这些类型的代码将导致类型耦合和维护负担。

持久层

    一个典型Web应用的另一端是持久层。这也是应用中最容易很快失控的地方。开发者通常低估了自己构建自己的持久层框架的挑战。一个定制的,内部开发的持久层不仅需要大量的开发时间,并且通常缺乏功能和难以管理。目前有许多解决这些问题的开源对象关系映射 (ORM) 框架。特别地,Hibernate 框架就允许Java中的对象-关系的持久性和查询服务。Hibernate 对已经熟悉了SQL 和JDBC API的Java开发者来或具有中度的学习曲线。Hibernate 的持久对象基于POJO和Java群集(collections)。此外,使用Hibernate 不和你的IDE接口。下面列出了你需要在持久性框架中编写的代码类型:

   1. 查询关系信息到对象中。Hibernate是通过称为HQL的OO查询语言,或者使用更有表现能力的规则API,来完成这个工作的。除了使用对象而不是表,使用字段而不是列的方式,HQL非常类似于 SQL。也有一些新的特定的HQL 语言特征需要学习;但是,它们是很容易理解和良好编写的。HQL是一种用于查询对象的自然语言,而对象,只需要很少的学习曲线吧。.
   2. 存储、更新和删除存储在数据库中的信息
   3. 高级的对象关系映射框架比如Hibernate支持大部分主流SQL数据库,它们支持父/子关系,事务,继承和多态。

下面是应该在持久层避免的一些事情:

   1. 业务逻辑应该置于应用的更高层中。这里只允许数据访问方法。
   2. 不应该使持久逻辑和表现逻辑耦合。避免表现组件如JSP或者基于servlet的类中的逻辑直接和数据访问进行通信。通过将持久性逻辑隔离在其自己的层中,应用将具有更加灵活的修改性而不影响到其他层的代码。例如, Hibernate可以使用其他持久框架和API代替,而不需要修改其它层中的代码。

业务层

    典型的Web应用的中间组件一般是业务层和服务层。从编程的角度来说,servicelayer经常被忽略。这种类型的代码散布于UI表现层和持久层并不是不多见。这些都不是正确的地方因为它导致了紧密耦合的应用和难以维护的代码。幸运的是,大多数框架都解决了这个问题。这个空间内最流行的两个框架是 Spring和PicoContainer。它们都被视为是具有非常小的足迹(footprint)并且决定如何将你的对象整合在一起的微容器(microcontainer)。这些框架都建立在一种叫做依赖性注入(dependency injection)(也称控制反转(inversion ofcontrol:IOC))的简单概念之上。我们将关注Spring中通过针对命名配置参数的bean属性的setter 注入的使用。Spring也允许一种更加高级的构造器注入(constructor injection)形式作为setter injection的可选替代。对象通过简单的XML 文件进行连接,该配置文件包含对各种对象的引用,比如事务管理处理器(transactionmanagement handler),对象工厂,包含业务逻辑的服务对象,以及数据访问对象(DAO)。

我们随后会用一些例子来澄清Spring中使用这些改变的方式。

业务层应该负责下面的问题:

   1. 处理应用的业务逻辑和业务校验
   2. 管理事务
   3. 允许与其他层进行交互的接口
   4. 管理业务级对象之间的依赖性
   5. 加入了表现和持久层之间的灵活性,以便它们不需要彼此进行直接通信
   6. 从表现层暴露上下文给业务层以获得业务服务
   7. 管理从业务层到表现层的实现

领域模型层

    最后,因为我们要解决实际的问题的web应用,我们需要一套在不同的层间移动的对象。领域模型层包含的是表达实际业务对象的对象,比如Order, OrderLineItem, Product等等。这一层允许能让开发者不再构建和维护不必要的数据传输对象DTO来匹配其领域对象。例如,Hibernate允许你读取数据库信息到一个领域对象的对象图中,以便你可以在离线的情况下将其表现在UI层中。这些对象可以被更新并跨过表现层发送回去,然后进行数据库更新。另外,你不再需要将对象转变成DTO,因为它们在不同的层间移动时可能会丢失事务。这种模型允许Java开发者能够以OO风格的方式很自然的处理对象,而不用编写额外的代码。
分享到:
评论

相关推荐

    应用分层及规约

    应用分层及规约的知识点涉及软件架构中的分层概念和各层之间的依赖关系,异常处理规约,以及分层领域模型规约。以下是对这些概念的详细阐述: ### 应用分层 在软件开发中,应用分层是一种常见的设计模式,它将应用...

    C/S、B/S、分层、多层架构参考

    总结起来,C/S和B/S架构分别代表了本地应用和Web应用的两种典型模型,而分层和多层架构则提供了系统设计的组织原则,帮助我们构建灵活、可维护的大型软件系统。理解并熟练运用这些知识点,对于任何IT从业者来说都是...

    当前流行的J2EE WEB应用架构分析

    本篇文章将深入探讨当前流行的J2EE Web应用架构,分析其关键技术组成及其在项目中的应用。 #### 二、J2EE Web应用架构概述 ##### 2.1 架构组成 J2EE架构主要包括以下几个核心组成部分: - **JavaServer Pages (JSP...

    DotNet分层

    本文将深入探讨DotNet分层架构的原理、结构及其在WindowsApp开发中的应用。 首先,我们要理解什么是分层架构。分层架构通常包括以下几个层次: 1. 表示层(Presentation Layer):这是用户与系统交互的界面,负责...

    c#经典数据库分层模型开发实例

    在C#中,可以利用类库项目(Class Library Projects)来组织各层,每个层作为独立的项目,通过引用互相连接。这样可以便于代码管理,每个层只关注自己的功能,减少层间的依赖。例如,数据访问层可以作为一个单独的...

    web三层架构体系 web架构

    ### Web三层架构体系详解 #### 一、三层架构概述 三层架构是一种常见的...通过上述详细的介绍,我们可以看到三层架构不仅能够有效地组织和管理代码,还能够清晰地划分各个层的职责,使得应用程序更易于维护和扩展。

    .net三层综合应用

    在".NET三层及六层综合应用"中,可能还包括更多的分层,如表示层(Presentation Layer)、服务层(Service Layer)、领域层(Domain Layer)和基础设施层(Infrastructure Layer)。这通常被称为六层架构,进一步...

    Struts2之模型驱动及分层架构初识案例struts004

    本案例“Struts2之模型驱动及分层架构初识”将深入探讨Struts2中的模型驱动模式和分层架构的概念及其应用。通过实践案例struts004,我们可以更直观地理解这些关键概念。 首先,让我们来了解**模型驱动**。在Struts2...

    SOA-SSH分层架构的设计与应用word版本.docx

    综上所述,SOA-SSH架构通过合理的分层设计和强大的技术支撑,为构建高效、稳定、易维护的Web应用程序提供了坚实的基础。随着技术的发展,不断优化和完善架构设计,可以使SOA-SSH架构更好地适应日益复杂的应用场景。

    Java分层思想.pdf

    1. 表现层(Presentation Layer):在Java Web应用中,表现层通常指的是使用JSP(JavaServer Pages)和Servlet技术构建的Web层,处理HTTP请求和响应,并与用户界面直接交互。在表现层,可以使用MVC(Model-View-...

    Web前端发展及应用.docx编程资料

    本文将详细探讨Web前端的发展历程及其应用,并重点关注不同发展阶段的技术特点、优势及挑战。 #### 一、简单明了的早期时代(Web 1.0) ##### 特点 - **定义**:这一时期通常被称为Web 1.0时代,主要特点是静态...

    asp.net分层例子

    ASP.NET分层架构是一种常见的软件开发模式,它将应用程序的不同组件分离到不同的...在C#中,利用面向对象的特性,我们可以有效地实现各层间的解耦,使得每个层只关注自己的职责,从而提高整体项目的质量和可扩展性。

    MVC分层模式例子

    MVC(Model-View-Controller)模式是一种广泛应用于Web应用程序设计的软件架构模式,它的核心思想是将业务逻辑、数据处理和用户界面进行分离,从而实现各部分的独立性和可维护性。在这个例子中,我们将深入探讨MVC...

    精通Eclipse,Web 开发-Java体系结构工具,框架及整合应用光盘

    这涉及到Java开发中的多个关键领域,包括集成开发环境(IDE)的选择与使用,Web应用程序的开发流程,以及如何利用Java技术栈来实现高效的软件设计和集成。 【描述】中再次强调了这个主题,暗示读者将深入学习...

    基于面向对象分层思想的PHP增删改查demo

    在这个"基于面向对象分层思想的PHP增删改查demo"中,我们可以看到如何将这一思想应用于实际的Web应用开发。 首先,"分层思想"是将一个复杂的系统分解为多个独立的层次,每个层次负责不同的职责。常见的三层架构包括...

    为何使用N层架构呢?

    以下是对N层架构及其各层的详细解释: 1. 表现层(Presentation Layer): 表现层是用户与系统交互的界面,负责显示信息和接收用户的输入。在ASP.NET中,这通常包括aspx页面、用户控件和服务器控件。这一层的职责是...

    后端研究-基于Java构建校务信息平台——MVC模式下的web应用开发.pdf

    1. **系统可分层**:系统可以分为多个层次进行设计和开发,每一层都有明确的接口,使得各层可以独立开发和测试。 2. **功能可递增**:系统支持的功能可以逐步增加,无需或很少改变现有代码,便于功能扩展。 3. **...

    <三层架构在企业中的应用>上机、课后、指导练习答案总结PPT

    在实际应用中,这通常包括Web页面、桌面应用程序或移动应用。 2. 业务逻辑层(Business Logic Layer): 这一层包含了应用程序的核心功能和业务规则。它接收来自表现层的请求,执行相应的业务操作,然后返回结果。...

    NET平台的分层架构与设计模式应用研究.docx

    ### .NET平台的分层架构与设计模式应用研究 #### 一、绪论 ##### 1.1 B/S系统概述 B/S(Browser/Server,浏览器/服务器模式)是一种网络结构模式,在这种模式下,客户端的主要应用软件是浏览器。B/S架构通过将...

    C#三层架构介绍

    - **可测试性**:由于各层之间的低耦合,可以更方便地进行单元测试和集成测试。 - **可扩展性**:当业务需求发生变化时,只需修改相应的层,而不会影响到其他层的功能。 - **复用性**:业务逻辑和数据访问代码可以在...

Global site tag (gtag.js) - Google Analytics