框架层次结构层次分为四层:表现层、持久层、业务层、域对象层。每个框架分别负责一个层次的实现,表现层我们使用Struts, 业务层使用Spring, 持久层使用Hibrenate。每层在应用程序中都有明确的责任。每一应用层彼此独立且保持一致。这些框架层次在以一种松散耦合的方式彼此作用而不用管低层的技术细节。
Struts是框架的表现层,Struts是对MVC构架的具体实现。它提供了一种便利的方式,可以用于将模块化的应用程序清楚地分成逻辑、表示和数据。
组装Struts Spring和Hibernate框架-2.1 Struts的MVC结构
Struts的MVC三层结构[3]:
视图层:Struts采用JSP作为MVC的视图。每一视图都是采用了定制标签库的JSP页面,这些定制标签库则由Struts框架提供。全部表单元素都是用定制标签编码的,所以这些页面能够很方便地同控制器交互。每一个表单都通过映射JSP到Servlet的请求这一方式指向控制器特定入口点。
控制层:控制器就是Java Servlet,由Struts框架提供,负责视图和模型之间的交互。控制器的每个入口点都由名为struts-config.xml的配置文件设置。该文件把来自视图的请求映射为特定的Java类以进行相应的处理,控制器还指定下一个视图的位置。
模型层:JavaBean就是模型的代表。对进入控制器的每个入口点来说,Bean的作用是存储从视图获取的信息,同时被称为“动作类”,一种Java类则被指定为对表单输入采取行动。动作类(Action Class)实现了业务逻辑。
Struts MVC结构图
Struts是当今流行的JSP Web框架。 Struts框架是一种基于Java的技术,Web应用程序开发人员通过它可充分利用面向对象设计、代码重用以及“编写一次、到处运行”的优点。Struts提供了一种创建具有良好可管理性的Web应用框架,其中对应用程序的显示、表示和数据的后端代码进行了抽象。
Struts的优点主要集中体现在如下[4]:
(1) Struts 将业务数据、页面显示、动作处理进行分离,有利于各部分的维护。
(2) Taglib 是Struts 的标记库,其灵活运用能大大提高开发效率。
(3) Struts的Valicator可以帮助完成验证工作,避免重复编写验证代码工作,减少了开发工作量,实现验证代码集中管理,其维护方便。
(4) 页面转发可以使系统的脉络更加清晰,可以在很大程度上提高系统的维护性,将是今后的一个发展方向。
(5) 通过Struts 提供的ActionForm封装web form中的元素,使重用web表单成为可能。
(6) Struts 采用 Front Controller模式来实现动作处理,让所有的动作请求都是经过一个统一入口,然后进行分发。该方式方便人们在入口中加入一些全局控制代码的实现,如安全控制、日志管理等。
下面是Struts在框架结构中所负责的工作:
(1) 为用户管理请求和响应;
(2) 提供一个控制器代理调用业务逻辑和其它上层处理;
(3) 处理从其它层掷出给一个Struts Action的异常;
(4) 为显示提供一个模型;
(5) 执行用户接口验证。
Spring实现了反转控制(Inversion of Control)和面向方面编程(Achievement-Oriented Programming)。Spring框架的能实现应用的分层架构,分层架构允许您选择使用哪一个组件。在应用中要使用的对象可以被一个简单的XML文件连在一起,这个XML文件含有到像事务管理器、对象工厂、包含业务逻辑的服务对象、和数据存取对象这些对象的引用。
组装Struts Spring和Hibernate框架-3.1 Spring框架的体系结构
Spring是框架的业务层,这个框架是一个分层架构,由 7 个定义良好的模块组成。如图3.3所示Spring体系结构。
Spring 框架体系结构
Spring 框架是一个分层架构,由 7 个定义良好的模块组成。Spring 模块构建在核心容器之上,核心容器定义了创建、配置和管理 bean 的方式,其主要优势有如下几点:
(1) Spring能有效地组织你的中间层对象。
(2) Spring能消除在许多工程中常见的对Singleton的过多使用。
(3) 通过一种在不同应用程序和项目间一致的方法来处理配置文件,消除各种自定义格式的属性文件的需要,仅仅需要看看类的JavaBean属性。反转控制的使用帮助完成了这种简化。
(4) Spring能够帮助我们真正意义上实现针对接口编程。
(5) Spring的设计会让使用它创建的应用尽可能少的依赖于它的APIs,在Spring应用中的大多数业务对象没有依赖于Spring。
(6) 使用Spring构建的应用程序易于单元测试。
(7) Spring使EJB成为一个实现选择,而不是必需的选择。你可以用POJO或当地EJB来实现业务接口,却不会影响到调用代码。
(8) Spring能使用AOP提供声明性事务管理,可以不直接操作JTA也能够对事务进行管理。
(9) Spring为数据存取提供了一个一致的框架,不论是使用JDBC还是O/R mapping的产品。
(10) MVC Web框架,提供一种清晰,无侵略性MVC实现方式。
Spring业务层在框架中负责下面这些事情:
(1) 管理事务;
(2) 预留和其它层交互的接口;
(3) 管理业务层对象之间的依赖;
(4) 增加在表现层和持久层之间的灵活性,使它们互不直接通讯;
(5) 从表现层中提供一个上下文给业务层获得业务服务;
(6) 管理从业务逻辑到持久层的实现;
(7) 处理应用程序的业务逻辑和业务验证;
Hibernate是一种ORM映射工具,它不仅提供了从Java类到数据表之间的映射,也提供了数据查询和恢复机制。相对于使用JDBC和SQL来手工操作数据库,使用Hibernate,可以大大减少操作数据库的工作量。Hibernate可以和多种Web服务器或者应用服务器良好集成。
Hibernate框架的体系结构图如图所示。
Hibernate的体系结构图
组装Struts Spring和Hibernate框架-4.2 Hibernate框架的优势
Hibernate是一个开放源代码的对象关系映射框架,它对JDBC进行了非常轻量级的对象封装,使得Java程序员可以随心所欲的使用对象编程思维来操纵数据库。Hibernate可以应用在任何使用JDBC的场合,既可以在Java的客户端程序实用,也可以在Servlet/JSP的Web应用中使用,Hibernate还可以在应用EJB的J2EE架构中取代CMP,完成数据持久化的重任。
Hibernate框架的优势有下面几点:
(1) Hibernate具有可扩展性;
(2) Hibernate既适用于独立的Java程序,也适用于Java Web应用,而且还可以在J2EE架构中取代CMP,完成持久化任务,Hibernate能集成到会话EJB和基于BMP的实体EJB中;
(3) Hibernate可以和多种WEB服务器,应用服务器良好集成,并且支持所有的数据库服务器;
(4) Hibernate有详细的参考文档,使用方便,容易上手。
下面是Hibernate持久层在框架中所负责的工作:
(1) 查询相关的信息成为对象。
Hibernate通过HQL的面向对象的查询语言或者使用条件表达式API来做这个事情。HQL非常类似于SQL。只是把SQL里的table和columns用Object和它的fields代替;
(2) 保存、更新、删除储存在数据库中的信息;
Hibernate这样的高级“对象-关系”映射框架提供对大多数主流SQL数据库的支持,它们支持“父/子”关系、事务处理、继承和多态。
域对象层,也叫DAO访问层,它负责封装底层的数据访问细节,不仅可能使概念清晰,而且可以提高开发效率。
域对象层主要做两件事:
(1) 编写相关接口: DAO类一般要使用Spring的声明式事务机制,而声明式事务机制是使用Spring AOP来实现的。Spring AOP默认使用的Java动态代理必须基于接口。本系统是面向接口编程;
(2)实现相关接口:在实现接口的同时,需要继承HibernateDaoSurpport类,这样可以省去对SessionFactory与HibernateTemplate的处理。