铁手剑谱

上善若水
数据加载中……
一种优雅的流行架构:Struts+Spring+Hibernate (1)

用java来建立一个很有价值的web 应用不是一个简单的任务。在架构这个应用时要考虑很多的因素和问题。从更高的层次来看,开发人员面临着关于如何构建用户接口,何处驻留业务逻辑,以及如何实现数据持久性这些问题。这3层都有各自的问题需要回答。而每一层又需要实现那些技术?应用如何设计来进行松散耦合并能进行灵活变更?应用架构是否允许某一层变更而不影响到其它的层次?应用应该如何处理容器一级的服务比如事务?

在为你的应用创建一个架构之前有许多问题需要澄清。幸运的是,有很多开发者都意识到这个问题,并建立了很多框架来解决这些问题。一个良好的框架可以让开发人员减轻重新建立解决复杂问题方案的负担和精力;它可以被扩展以进行内部的定制化;并且有强大的用户社区来支持它。框架通常能很好的解决一个问题。然而,你的应用是分层的,可能每一个层都需要各自的框架。仅仅解决UI问题并不意味着你能够很好的将业务逻辑和持久性逻辑和UI 组件很好的耦合。例如,你不应该使具有JDBC代码的业务逻辑放入控制器之中,这不是控制器应该提供的功能。一个UI 控制器应该是轻量化的组件,由它代表对UI范围之外的其它应用层的服务调用。良好的框架自然地形成代码分离的原则。更为重要的是,框架减轻了开发人员从头构建持久层代码的精力,从而集中精力来应用逻辑上,这对客户端来说更为重要。

本文讨论了如何结合几个著名的框架来达到松散耦合,如何设计你的架构,以及如何达到各个层次的一致性设计。面临的挑战是,将框架整合起来,以使每一层都向另外的层次以一种松散的方式来暴露接口,而不管底层功能使用的是什么技术。本文还讨论整合3种著名开源框架的一种策略。对表现层,我们使用Struts;业务层使用Spring;对于持久层我们使用的是Hibernate。你尽可以取代这里的某个框架而使用你喜欢的框架已达到同样的效果。图1显示了框架被整合起来时,从最高层次看到的视图。

clip_image001_0007.gif


 

应用层

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

表现层

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

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

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

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

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

持久层

一个典型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代替,而不需要修改其它层中的代码。

业务层

典型的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)。

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

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

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

领域模型层

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

整合一个简单的例子

到此,应该对各种层次和组件有一个高层的理解了罢。可以开始一些实践了。再次说明。我们的例子整合了Struts, Spring, 和Hibernate 框架。每个框架都包含大量的内容细节,我们不会多述。我们的目的使用一个例子向你说明如何将它们整合在一起构建一个优雅的Web应用架构。实例将演示一个请求是如何得到各层的服务的。此应用的用户可以将一个订单保存在数据库中并且察看数据中的已有订单。进一步的增强允许将用户更新和删除现有订单。

首先,我们将常见我们的领域对象,因为它们是要和各层沟通的。这些对象将允许我们能够定义那些对象需要持久化,那些业务逻辑需要提供,以及应该设计那些表现接口。接下来,我们将使用Hibernate 来为领域对象配置持久层和定义对象关系映射。然后,我们将定义和配置我们的业务层。在完成这些组件后,我们将讨论如何使用Spring将这些层关联起来。最后,我们将提供一个表现层,它知道如何与业务服务层通信以及如何处理来自于其他层的例外。

posted on 2005-04-29 11:42 铁手 阅读(16383) 评论(21)  编辑  收藏 所属分类: Java企业架构

评论

# re: 一种优雅的流行架构:Struts+Spring+Hibernate (1) 2005-04-30 10:20 Samuel

并不一定需要struts,Spring的MVC就足够用了,而且很好用
  回复  更多评论    

# re: 一种优雅的流行架构:Struts+Spring+Hibernate (1) 2005-05-16 17:11 jony

看了您的文章,对struts+spring+hibernate的概念有了一定的了解,但是还不知道怎么整合起来使用。
  回复  更多评论    

# re: 一种优雅的流行架构:Struts+Spring+Hibernate (1) 2005-07-19 15:02 

翻译老外的文章,应该注明啊
  回复  更多评论    

# re: 一种优雅的流行架构:Struts+Spring+Hibernate (1) 2005-07-19 15:12 铁手

yes,from Oreiley
  回复  更多评论    

# 有没有学习这三者的一个完整例子 2005-07-28 17:49 liuliu

有没有学习这三者的一个完整例子,小的项目,我想通过实例来学习这些东西,希望能给指点一下,
  回复  更多评论    

# re: 一种优雅的流行架构:Struts+Spring+Hibernate (1) 2005-07-29 09:27 铁手

You can learn it from APPFUSE,it can be found at Java.net
  回复  更多评论    

# l 2005-11-15 14:49 f

ddd
  回复  更多评论    

# re: 一种优雅的流行架构:Struts+Spring+Hibernate (1) 2005-12-23 21:05 kingbit

  回复  更多评论    

# re: 一种优雅的流行架构:Struts+Spring+Hibernate (1) 2006-01-23 11:07 小猪

铁手大哥:

你的文章不错,但是就是缺少个例子,你个例子
  回复  更多评论    

# re: 一种优雅的流行架构:Struts+Spring+Hibernate (1) 2006-03-11 13:18 scorpional

感觉比较生硬和抽象!
  回复  更多评论    

# re: 一种优雅的流行架构:Struts+Spring+Hibernate (1) 2006-07-05 19:40 agou

我还是有一点不明白Spring+struts 是否有必要。意义是什么
  回复  更多评论    

# re: 一种优雅的流行架构:Struts+Spring+Hibernate (1) 2006-08-27 09:20 sp

@jony
能否有一个完整的例子,让我们看看
请问那里能看到一完事的例子
  回复  更多评论    

# re: 一种优雅的流行架构:Struts+Spring+Hibernate (1) 2006-09-10 11:04 zj

能否有一个完整的例子,让我们看看
  回复  更多评论    

# re: 一种优雅的流行架构:Struts+Spring+Hibernate (1) 2006-10-09 23:48 rainy21cn

Struts较springMVC容易掌握,所以还是有其可取之处,开发成本相对更低一些,夏昕的spring开发向导也有三者配合使用的信息,并且讲的很透彻,大家可以借鉴一下
  回复  更多评论    

# re: 一种优雅的流行架构:Struts+Spring+Hibernate (1) 2006-11-09 14:14 野草[匿名]

我以前做了一个很简单的例子,不是很好,给大家参考.
http://www.15913.com/download/file/10061017/15913.com-withlib.rar
等做出更好的例子再贴出来.
  回复  更多评论    

# re: 一种优雅的流行架构:Struts+Spring+Hibernate (1) 2006-11-16 17:08 maomao[匿名]

很不错,谢谢!
  回复  更多评论    

# re: 一种优雅的流行架构:Struts+Spring+Hibernate (1) 2007-02-10 17:38 幻想~@@~

不错 辛苦了
能给个事例吗???
  回复  更多评论    

# re: 一种优雅的流行架构:Struts+Spring+Hibernate (1) 2007-02-10 17:39 幻想~@@~

看到了谢谢
学习一下。。。
  回复  更多评论    

# re: 一种优雅的流行架构:Struts+Spring+Hibernate (1) 2007-06-29 09:47 lwie

很不错的,我要学习了地方多呢
  回复  更多评论    

# re: 一种优雅的流行架构:Struts+Spring+Hibernate (1) 2007-06-30 00:18 blett

很不错的一篇文章......
但还是有些地方不太明白,现在的spring框架功能越来越强大,从MVC到hibernate都包括了,而且封装的比较完美,那么在在某种程度上来说SSH(STRUTS+SPRING+HIBERNATE)是否可以被spring一个框架可以替代呢?

但在实际的项目中,这样做的几率好象很少;我们在一个web项目中如何最大限度的利用各种流行框架的优点呢?

铁手能否指点一下?

thx
  回复  更多评论    

# re: 一种优雅的流行架构:Struts+Spring+Hibernate (1)[未登录] 2008-05-06 23:03 kk

讲得不错,浅显易懂,谢谢了!
  回复  更多评论    

只有注册用户登录后才能发表评论。


网站导航: