1.1 框架
用java 来建立一个很有价值的web 应用不是一个简单的任务。在架构这个应用时要考虑很多的因素和问题。从更高的层次来看,开发人员面临着关于如何构建用户接口,何处驻留业务逻辑,以及如何实现数据持久性这些问题。这3 层都有各自的问题需要回答。而每一层又需要实现那些技术?应用如何设计来进行松散耦合并能进行灵活变更?应用架构是否允许某一层变更而不影响到其它的层次?应用应该如何处理容器一级的服务比如事务?
在为你的应用创建一个架构之前有许多问题需要澄清。幸运的是,有很多开发者都意识到这个问题,并建立了很多框架来解决这些问题。一个良好的框架可以让开发人员减轻重新建立解决复杂问题方案的负担和精力;它可以被扩展以进行内部的定制化;并且有强大的用户社区来支持它。框架通常能很
好的解决一个问题。然而,你的应用是分层的,可能每一个层都需要各自的框架。仅仅解决UI 问题并不意味着你能够很好的将业务逻辑和持久性逻辑和UI 组件很好的耦合。例如,你不应该使具有JDBC 代码的业务逻辑放入控制器之中,这不是控制器应该提供的功能。一个UI 控制器应该是轻量化的组件,由它代表对UI 范围之外的其它应用层的服务调用。良好的框架自然地形成代码分离的原则。更为重要的是,框架减轻了开发人员从头构建持久层代码的精力,从而集中精力来应用逻辑上,这对客户端来说更为重要。
本文讨论了如何结合几个著名的框架来达到松散耦合,如何设计你的架构,以及如何达到各个层次的一致性设计。面临的挑战是,将框架整合起来,以使每一层都向另外的层次以一种松散的方式来暴露接口,而不管底层功能使用的是什么技术。本文还讨论整合3 种著名开源框架的一种策略。对表现层,我们使用Struts;业务层使用Spring;对于持久层我们使用的是Hibernate。你尽可以取代这里的某个框架而使用你喜欢的框架已达到同样的效果。
1.2 应用层
许多设计良好的web 应用,可以被按职责分为四层。这些层次是表现层、持久层、业务层、和领域模型层。每一个层次都有其独特的职责,不能把各自的功能与其它层次相混合。每一个应用层都应该和其它层隔离开来,但允许使用接口在层间进行通信。我们开始来看看每个层,并讨论一下它们各自都应该提供什么和不应该提供什么。
1.2.1 表现层
一个典型的web 应用的末端是表现层。许多Java 开发者都知道Struts 提供了什么东西。然而,太多时候,耦合代码比如业务逻辑被放进org.apache.struts.Action 中。所以,我们先总结一下Struts 之类的框架应该提供什么。下面就是Struts 的职责所在:
管理用户的请求和响应
提供一个控制起来将调用委托到业务逻辑和其他上游处理
将来自于抛出例外的其他层的例外处理到Struts Action 中
组装可以在视图中表现的模型对象
执行UI 校验
下面是一些经常可以使用Struts 进行编码但是不应该和表现层关联的事情:
直接和数据库交互,比如JDBC 调用
与应用相关的业务逻辑和校验
事务管理
在表现层中引入这些类型的代码将导致类型耦合和维护负担。
1.2.2 持久层
一个典型Web 应用的另一端是持久层。这也是应用中最容易很快失控的地方。开发者通常低估了自己构建自己的持久层框架的挑战。一个定制的,内部开发的持久层不仅需要大量的开发时间,并且通常缺乏功能和难以管理。目前有许多解决这些问题的开源对象关系映射 (ORM) 框架。特别地,Hibernate 框架就允许Java 中的对象-关系的持久性和查询服务。Hibernate 对已经熟悉了SQL 和JDBC API 的Java 开发者来或具有中度的学习曲线。Hibernate 的持久对象基于POJO 和Java 群集(collections)。此外,使用Hibernate 不和你的IDE 接口。下面列出了你需要在持久性框架中编写的代码类型:
查询关系信息到对象中。Hibernate 是通过称为HQL 的OO 查询语言,或者使用更有表现能力的规则API,来完成这个工作的。除了使用对象而不是表,使用字段而不是列的方式,HQL非常类似于 SQL。也有一些新的特定的HQL 语言特征需要学习;但是,它们是很容易理解和良好编写的。HQL 是一种用于查询对象的自然语言,而对象,只需要很少的学习曲线吧。
存储、更新和删除存储在数据库中的信息 高级的对象关系映射框架比如Hibernate 支持大部分主流SQL 数据库,它们支持父/子关系,事务,继承和多态。
下面是应该在持久层避免的一些事情:
业务逻辑应该置于应用的更高层中。这里只允许数据访问方法。
不应该使持久逻辑和表现逻辑耦合。避免表现组件如JSP 或者基于servlet 的类中的逻辑直接和数据访问进行通信。通过将持久性逻辑隔离在其自己的层中,应用将具有更加灵活的修改性而不影响到其他层的代码。例如, Hibernate 可以使用其他持久框架和API 代替,而不需要修改其它层中的代码。
1.2.3 业务层
典型的Web 应用的中间组件一般是业务层和服务层。从编程的角度来说,service layer 经常被忽略。这种类型的代码散布于UI 表现层和持久层并不是不多见。这些都不是正确的地方因为它导致了紧密耦合的应用和难以维护的代码。幸运的是,大多数框架都解决了这个问题。这个空间内最流行的两个框架是Spring 和PicoContainer。它们都被视为是具有非常小的足迹(footprint)并且决定如何将你的对象整合在一起的微容器(microcontainer)。这些框架都建立在一种叫做依赖性注入(dependency
injection) (也称控制反转(inversion of control:IOC))的简单概念之上。我们将关注Spring 中通过针对命名配置参数的bean 属性的setter 注入的使用。Spring 也允许一种更加高级的构造器注入(constructor injection)形式作为setter injection 的可选替代。对象通过简单的XML 文件进行连接,该配置文件包含对各种对象的引用,比如事务管理处理器(transaction management handler),对象工厂,包含业务逻辑的服务对象,以及数据访问对象(DAO)。
业务层应该负责下面的问题:
处理应用的业务逻辑和业务校验
管理事务
允许与其他层进行交互的接口
管理业务级对象之间的依赖性
加入了表现和持久层之间的灵活性,以便它们不需要彼此进行直接通信
从表现层暴露上下文给业务层以获得业务服务
管理从业务层到表现层的实现
1.2.4 领域模型层
最后,因为我们要解决实际的问题的web 应用,我们需要一套在不同的层间移动的对象。领域模型层包含的是表达实际业务对象的对象,比如Order, OrderLineItem, Product 等等。这一层允许能让开发者不再构建和维护不必要的数据传输对象DTO 来匹配其领域对象。例如, Hibernate 允许你读取数据库信息到一个领域对象的对象图中,以便你可以在离线的情况下将其表现在UI 层中。这些对象可以被更新并跨过表现层发送回去,然后进行数据库更新。另外,你不再需要将对象转变成DTO,因为它们在不同的层间移动时可能会丢失事务。这种模型允许Java 开发者能够以OO 风格的方式很自然的处理对象,而不用编写额外的代码。
分享到:
相关推荐
SSH整合jar包是Java开发中常见的一种框架集成方式,它涉及到Spring、Struts2和Hibernate这三个主流的开源框架。在Java Web开发中,SSH(Spring、Struts2、Hibernate)被广泛使用,因为它们能够有效地解决企业级应用...
SSH整合是Java Web开发中的一种常见模式,它结合了Struts、...但随着技术的发展,现在Spring Boot等一站式解决方案越来越流行,SSH整合的应用逐渐减少,但其背后的理念和知识点仍然对理解现代Java Web开发至关重要。
Spring框架是SSH整合中的基石,它通过IoC(Inversion of Control)和AOP(Aspect-Oriented Programming)理念,提供了强大的依赖注入和面向切面编程功能。IoC使得应用程序的组件之间解耦,而AOP则允许开发者定义横切...
SSH整合是指将Struts2、Hibernate和Spring这三个开源框架整合在一起,用于构建高效、灵活的企业级Web应用程序。在Java开发领域,SSH框架因其强大的功能和灵活性而被广泛应用。以下是关于SSH整合及其相关jar包的详细...
SSH框架整合不仅是技术层面的挑战,更是一种设计理念的体现。通过将MVC(Model-View-Controller)、依赖注入(Dependency Injection)和对象关系映射(Object-Relational Mapping)三大概念有机融合,实现了代码的高...
SSH2整合源码详解 SSH2是Spring、Struts2和Hibernate3三个开源框架的集成,通常用于构建大型的企业级Web应用。这三个框架各司其职,Spring负责管理应用程序的bean,提供AOP(面向切面编程)和IoC(控制反转);...
#### 一、SSH整合理念与背景 **1.1 框架概述** 在构建复杂的Web应用程序时,开发人员需要面对诸多挑战,包括如何构建用户界面(UI)、业务逻辑(BL)的存放位置以及数据持久性的实现方式等。每一层都需要解决特定的...
SSH(Struts+Spring+Hibernate)是一个经典的Java Web开发...此外,随着技术的发展,Spring Boot和Spring Framework 5等现代框架的兴起,SSH的使用逐渐减少,但了解SSH仍然有助于理解现代框架的设计理念和工作原理。
SSH整合源码主要涉及到三个关键组件:Struts、Spring和Hibernate,这三者构成了Java Web开发中的经典MVC...同时,了解SSH整合也有助于过渡到其他现代框架,如Spring Boot和Spring MVC,因为它们都基于相似的设计理念。
**Maven简介** Maven是Java开发中的一个项目管理和综合工具,由Apache...通过Maven进行SSH整合,可以使开发更有序,依赖管理更清晰,提高开发效率。同时,Maven的自动化构建能力也有助于持续集成和部署流程的优化。
**一、SSH整合理念** 在《Struts+Spring+Hibernate整合教程》中,作者陈文光详细阐述了Struts、Spring和Hibernate三大框架的整合策略,旨在构建一个结构清晰、可扩展性强且易于维护的Web应用程序。此教程不仅提供了...
#### 一、SSH整合理念 在现代Web应用程序开发中,使用多种框架和技术来构建高效、可扩展且易于维护的应用程序已成为常态。本教程旨在介绍如何有效地整合Struts(负责表现层)、Spring(负责业务层)和Hibernate...
在SSH整合的理念中,框架作为软件开发的基石,承担着构建应用架构和处理复杂问题的重担。一个良好的框架能够减轻开发人员重复构建已有解决方案的负担,并可以被定制化来满足特定需求,同时拥有强大的用户社区支持。...
然而,随着微服务和前后端分离理念的发展,现代Web开发更多地倾向于使用Spring Boot和React/Vue等技术栈,SSH2的使用逐渐减少。但了解SSH2的整合,对于理解现代框架的工作原理和历史背景仍然具有重要意义。
SSH整合理念 ##### 1.1 框架概述 在构建有价值的Web应用程序时,Java开发者面临诸多挑战,包括但不限于如何构建用户界面、如何处理业务逻辑及数据持久化等问题。为了解决这些问题,开发者们创造了各种框架。本节...
SSH整合理念 在软件开发过程中,特别是构建大型Web应用程序时,使用多个框架进行整合是非常常见的做法。这种整合不仅可以提高开发效率,还能确保系统的可扩展性和灵活性。Struts、Spring 和 Hibernate 是三种广泛...
SSH整合涉及到多个层次的配置和交互,理解每个框架的核心机制和整合要点至关重要。通过深入学习和实践,开发者可以构建出高效、稳定的企业级Java Web应用。在实际项目中,还需要根据业务需求灵活调整配置,优化性能...
### SSH整合详解:Struts, Spring, Hibernate在MyEclipse6.5下的融合应用 #### 编写目的 本文旨在详尽阐述如何在MyEclipse6.5环境下整合SSH(Struts, Spring, Hibernate)框架,以期为初学者及开发者提供一条清晰...