java各种系统框架图简介_第1页
java各种系统框架图简介_第2页
java各种系统框架图简介_第3页
java各种系统框架图简介_第4页
java各种系统框架图简介_第5页
已阅读5页,还剩1页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

JAVA 各种系统框架图简介 原文出处:/6517/viewspace-609654 1.Spring 架构图 Spring 是一个开源 框架,是为了解决企业 应用程序开发复杂性而创建的。 框架的主要优势之一就是其分层架构,分层架构允许您选择使用哪一个组件, 同时为 J2EE 应用程序开发提供集成的框架。Spring 框架的功能可以用在任何 J2EE 服务器中,大多数功能也适用于不受管理 的环境。Spring 的核心要点是: 支持不绑定到特定 J2EE 服务的可重用业务和数据访问对象。这样的对象可以 在不同 J2EE 环境(Web 或 EJB )、独立应用程序、测试 环境之间重用。 组成 Spring 框架的每个模块(或组件)都可以单独存在,或者与其他一个或 多个模块联合实现。每个模块的功能如下: 核心容器:核心容器提供 Spring 框架的基本功能。核心容器的主要组件是 BeanFactory ,它是 工厂模式的实现。BeanFactory 使用控制反转 (IOC ) 模式将应用程序的配置和依赖性规范与实 际的应用程序代码 分开。 Spring 上下文:Spring 上下文是一个配置文件,向 Spring 框架提供上下文信息。Spring 上下文 包括企业服务,例如 JNDI 、EJB、电子邮件、国际化、校验和调度功能。 Spring AOP : 通过配置管理特性,Spring AOP 模块直接将面向方面的编程 功能集成到了 Spring 框架中。所以,可以很容易地使 Spring 框架管理的任何对象支持 AOP 。Spring AOP 模块 为基于 Spring 的应用程序中的对象提供了事务管理服务。通过使用 Spring AOP ,不用依赖 EJB 组 件,就可以将声明性事务管理集成到应用程序中。 Spring DAO :JDBC DAO 抽象层提供了有意义的异常层次结构,可用该结构来管理异常处理和 不同数据库 供应商抛出的错误消息。异常层次结构简化了错误处理,并且极大地降低了需要编写 的异常代码数量(例如打开和关闭连接)。Spring DAO 的面向 JDBC 的异常遵从通用的 DAO 异常 层次结构。 Spring ORM :Spring 框架插入了若干个 ORM 框架,从而提供了 ORM 的对象关系工具,其中 包括 JDO 、Hibernate 和 iBatis SQLMap 。所有这些都遵从 Spring 的通用事务和 DAO 异常层次结 构。 2.ibatis 架构图 ibatis 是一个基于 Java 的持久层框架。 iBATIS 提供的持久层框架包括 SQL Maps 和 Data Access Objects ( DAO ),同时还提供一个利用这个框 架开发的 JPetStore 实例。 IBATIS :最大的优点是可以有效的控制 sql 发送的数目,提高数据层的执行效率!它需要程序员自 己去写 sql 语句,不象 hibernate 那样是完全面向对象的,自动化的,ibatis 是半自动化的,通过表和对象 的映射以及手工书写的 sql 语句,能够实现比 hibernate 等更高的查询效率。 Ibatis 只是封装了数据访问层,替我们做了部分的对象关系映射。但代价是必须要写 xml 配置文件, 相对于 Hibernate 还要写很多 sql 。Hibernate 通过工具直接从数据库模式生成实体类和基本的配置文件, 而且大部分情况下不需要我们写 sql ,会较大的提升开发效率。但这些也有很多的局限性,尤其是对环境 的要求较高(数据库设计,对象设计,团队的协作等)。 个人感觉 Ibatis 对项目比较有意义的地方在于 它小巧灵活,可扩展,封装了数据访问层(事务,缓存,异常,日志),并提供了 DAO 框架支持。 利用 Ibatis 我们可以做到代码和 sql 的分离,只要 sql 能够解决的问题,Ibatis 就能帮我们较容易的 解决,同时也使我们的项目对某一框架的依赖性变小(因为 Ibatis 是非侵入性的)。这将极大的降低项目 风险,减少解决复杂问题的时间,使项目的维护变得简单。 Ibatis 对于应用的修改,调试,扩充和维护将会变得容易自然。修改时,我们主要修改的是代表模型 的实体对象,xml 配置文件中的 sql ,和/ 或配置文件的 ResultMap (很多时候是不需要的)。同时,sql 和代码分离,我们不用在代码的 StringBuffer 的 append 方法之间寻找需要修改的 sql 。配置文件中的 sql 便利了我们的调试和对 sql 的评审及以后的 sql 重用。 3.structs1 架构图 Struts 是 Apache 基金会 Jakarta 项目组的一个 Open Source 项目,它采 用 MVC 模式,能够很好地帮助 java 开发者利用 J2EE 开发 Web 应用。和其他 的 java 架构一样,Struts 也是面向对象设计,将 MVC 模式“ 分离显示逻辑和 业务逻辑“ 的能力发挥得淋漓尽致。Structs 框架的核心是一个弹性的控制层, 基于如 Java Servlets ,JavaBeans ,ResourceBundles 与 XML 等标准技术 , 以及 Jakarta Commons 的一些类库。Struts 有一组相互协作的类(组件)、 Serlvet 以及 jsp tag lib 组成。基于 struts 构架的 web 应用程序基本上符 合 JSP Model2 的设计标准,可以说是一个传统 MVC 设计模式的一种变化类型。 Struts 有其自己的控制器(Controller ),同时整合了其他的一些技术 去实现模型层(Model )和视图层(View )。在模型层,Struts 可以很容易 的与数据访问技术相结合,如 JDBC / EJB ,以及其它第三方类库,如 Hibernate / iBATIS ,或者 Object Relational Bridge( 对象关系桥) 。在 视图层,Struts 能够与 JSP ,包括 JSTL 与 JSF ,以及 Velocity 模板,XSLT 与其它表示层技术。 Struts 为每个专业的 Web 应用程序做背后的支撑,帮助为你的应用创建一 个扩展的开发环境。 Client browser (客户浏览器) 来自客户浏览器的每个 HTTP 请求创建一个事件。Web 容器将用一个 HTTP 响应 作出响应。 Controller (控制器) 控制器接收来自浏览器的请求,并决定将这个请求发往何处。就 Struts 而言, 控制器是以 servlet 实现的一个命令设计模式。struts-config.xml 文件配置 控制器。 业务逻辑 业务逻辑更新模型的状态,并帮助控制应用程序的流程。就 Struts 而言,这 是通过作为实际业务逻辑“ 瘦” 包装的 Action 类完成的。 Model (模型)的状态 模型表示应用程序的状态。业务对象更新应用程序的状态。ActionForm. bean 在会话级或请求级表示模型的状态,而不是在持久级。JSP 文件使用 JSP 标 记读取来自 ActionForm. bean 的信息。 View (视图) 视图就是一个 JSP 文件。其中没有流程逻辑,没有业务逻辑,也没有模型信息 - 只有标记。标记是使 Struts 有别于其他框架(如 Velocity)的因素之一 4.structs2 架构图 Struts 2 相对于 Struts 1.X ,将实现用户业务逻辑(Action )同 Servlet API 分离开,这种分离机制,是采用了拦截器或者拦截器栈(拦截器 链)。拦截器是 Struts 2 的核心内容之一。 Struts 2 内建了多个拦截器和拦截器栈(由多个拦截器形成的拦截器链), 将用户的 Web 请求进行拦截处理,从而提供了更加丰富的功能,例如数据类型 转换、国际化、文件上传等。 5.Hibernate 架构图 Hibernate 是一个开放源代码 的对象关系映射框架,它对 JDBC 进行了非 常轻量级的对象封装,使得 Java 程序员可以随心所欲的使用对象编程思维来 操纵数据库。Hibernate 可以应用在任何使用 JDBC 的场合,既可以在 Java 的 客户端程序使用,也可以在 Servlet/JSP 的 Web 应用中使用,最具革命 意义 的是,Hibernate 可以在应用 EJB 的 J2EE 架构中取代 CMP ,完成数据持久化 的重任。 Hibernate 的核心接口一共有 5 个,分别为: Session 、SessionFactory 、Transaction 、Query 和 Configuration 。这 5 个核心接口在任何开发中都会用到。通过这些接口,不仅可以对持久化对象进 行存取,还能够进行事务控制。下面对这五个核心接口分别加以介绍。 Session 接口:Session 接口负责执行被持久化对象的 CRUD 操作(CRUD 的任务是完成与数据库的交流,包含了很多常见的 SQL语句。) 。但需要注意 的是 Session 对象是非线程安全的。同时,Hibernate 的 session 不同于 JSP 应用中的 HttpSession 。这里当使用 session 这个术语时,其实指的是 Hibernate 中的 session ,而 以后会将 HttpSesion 对象称为用户 session 。 SessionFactory 接口:SessionFactory 接口负责初 始化 Hibernate 。 它充当数据存储源的代理,并负责创建 Session 对象。这里用到了工厂模式。 需要注意的是 SessionFactory 并不是轻量级的,因为一般情况下,一个项目 通常只需要一个 SessionFactory 就够,当需要操作多个数据库时,可以为每 个数据库指定一个 SessionFactory 。 Configuration 接口:Configuration 接口负责配置并启动 Hibernate , 创建 SessionFactory 对象。在 Hibernate 的启动的过程中,Configuration 类的实例首先定位映射文档位置、读取配置,然后创建 SessionFactory 对象。 Transaction 接口:Transaction 接口负责事务相关的操作。它是可选的, 开发人员也可以设计编写自己的底层事务处理代码。 Query 和 Criteria 接口:Query 和 Criteria 接口负责执行各种数据库 查询。它可以使用 HQL

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论