对于J2EE体系架构的理解

对于J2EE体系架构的理解一、何为J2EE?J2EE架构是使用Java技术开发企业级应用的一种事实上的工业标准,它是Java技术不断适应和促进企业级应用过程中的产物。Java平台有三个版本:适用于小型设备和智能卡的J2ME(Java2PlatformMicroEdition)、适用于桌面系统的J2SE和适用于企业级应用的J2EE。Sun推出J2EE的目的是为了克服传统客户端\服务端模式的弊病,迎合Browser/Server架构的潮流,为应用Java技术开发服务器端应用提供一个平台独立的、可移植的、多用户的、安全的和基于

大家好,欢迎来到IT知识分享网。

一、何为J2EE?

J2EE架构是使用Java技术开发企业级应用的一种事实上的工业标准,它是Java技术不断适应和促进企业级应用过程中的产物。Java平台有三个版本:适用于小型设备和智能卡的J2ME(Java 2 Platform Micro Edition)、适用于桌面系统的J2SE和适用于企业级应用的J2EE。Sun推出J2EE的目的是为了克服传统客户端\服务端模式的弊病,迎合Browser/Server架构的潮流,为应用Java技术开发服务器端应用提供一个平台独立的、可移植的、多用户的、安全的和基于标准的企业级平台,从而简化企业应用的开发、管理和部署。J2EE是一个标准,而不是一个现成的产品。各个平台开发商按照J2EE规范分别开发了不同的J2EE应用服务器,J2EE应用服务器是J2EE企业级应用的部署平台。由于它们都遵循了J2EE规范,因此,使用J2EE技术开发的企业级应用可以部署在各种J2EE应用服务器上。

二、体系结构

J2EE的体系结构可以分为四层,如下图所示:

图1 J2EE体系结构

·客户端层:负责与用户直接交互,J2EE支持多种客户端,所以客户端既可以是WEB浏览器,也可以是专用的Java客户端。

·服务器端组件层:本层是为了基于WEB的应用服务的,利用J2EE中的JSP与Java Servlet技术,可以响应客户端的请求,并向后访问封装有业务逻辑的组件。

·EJB层:本层主要封装了业务逻辑,提供了事务处理,负载均衡、安全、资源连接等各种基本服务,程序在编写EJB时可以不关心这些基本的服务,集中注意力于业务逻辑的实现。

·企业信息系统层:企业信息系统层包括了企业的现有系统(包括数据库系统、文件系统),J2EE提供了多种技术以访问这些系统,如JDBC访问DBMS。

三、组件支持

J2EE应用程序是由组件构成的。J2EE组件是具有独立功能的软件单元,它们通过相关的类和文件组装成J2EE应用程序,并与其他组件交互。J2EE规范中定义了下列J2EE组件:

(1)客户层组件,包括客户端应用程序和Applets;

(2)Web层组件,包括Java Servlet和Java Server Pages(JSP);

(3)业务层组件,即Enterprise JavaBeans(EJB)。

1.客户层组件

J2EE应用程序可以是基于Web方式的,也可以是基于传统方式的。

Web层组件:J2EE Web层组件可以是JSP页面或Servlets。根据J2EE规范,静态的HTML页面和Applets都不是Web层组件。Web层可能包含某些JavaBean对象来处理用户输入,并把输入发送给运行在业务层上的enterprise bean来进行处理。

2.业务层组件

业务层的代码逻辑用来满足银行、零售、金融等特殊商务领域的需要,由运行在业务层上的enterprise bean进行处理。

有三种企业级的bean:会话(session)beans、实体(entity)beans和消息驱动(message-driven)beans。会话bean表示与客户端程序的临时交互,当客户端程序执行完毕,会话bean和相关数据就会消失。相反,实体bean表示数据库表中一行永久的记录,当客户端程序中止或服务器关闭时,就会有潜在的系统服务保证实体bean的数据得以保存。消息驱动bean结合了会话bean和JMS的消息监听器的特性,允许一个业务层组件异步接收JMS消息。

3.企业信息系统层

企业信息系统层处理企业信息系统软件,包括企业基础建设系统,如企业资源计划(ERP)、大型机事务处理、数据库系统和其他的遗留信息系统等。例如,J2EE应用组件可能为了数据库连接需要访问企业信息系统。

四、技术支持规范

在J2EE技术支持规范中,J2EE平台包括由一整套服务(services)、应用程序接口(APIs)和协议构成,可用于开发一般的多层应用和基于WEB的多层应用,是J2EE的核心和基础,它对开发基于Web的多层应用提供了功能支持,下面对J2EE中的主要技术规范进行简单的描述。

1.JDBC(Java Database Connectivity)

JDBC接口为访问不同的数据库提供了一种统一的途径,像ODBC一样,JDBC对开发者屏蔽了一些细节问题。另外,JDBC对数据库的访问也具有平台无关性。

2.JNDI(Java Name and Directory Interface)

JNDIAPI用于执行名字和目录服务。它提供了一致的模型来存取和操作企业级的资源,如DNS和LDAP、本地文件系统、应用服务器中的对象。

3.EJB(Enterprise JavaBean)

EJB技术是在Java Bean本地组件技术基础上开发的面向服务器端分布应用的组件技术。EJB是Sun推出的J2EE规范的一部分,自从J2EE推出之后,得到了广泛的发展,已经成为应用服务器端的标准技术。JB提供了一个开发和实施分布式商务逻辑的框架,大大地简化了具有可伸缩性和高度复杂的企业级应用的开发。EJB规范定义了EJB组件如何与EJB容器(container)进行交互。容器负责提供公用服务,如目录服务、事务管理、安全性、资源缓冲池以及容错性等。但EJB并不是实现J2EE的唯一途径。正是由于J2EE的开放性,使得有的厂商能够以一种和EJB平行的方式来达到同样的目的。

EJB基于Java语言,提供了基于Java二进制字节代码的重用方式。EJB技术的推出,使得用Java基于组件技术开发服务器端分布式应用成为可能。从企业应用多层结构的角度来看,EJB是业务逻辑层的中间件技术。与JavaBeans的关键不同是它提供了事务处理的能力。

4.JSP(Java Server Pages)

JSP页面由HTML代码和嵌入其中的Java代码所组成。服务器在页面被客户端所请求后对页面中的Java代码进行处理,然后将生成的HTML页面返回给客户端的浏览器。

5.Java Servlet Servlet是一种小型的Java程序,它扩展了Web服务器的功能。

作为一种服务器端的应用,和CGI脚本类似,当被请求时开始执行。Servlet提供的功能与JSP类似,但实现方式不同。JSP通常在大量的HTML代码中嵌入少量的Java代码,而servlets全部由Java写成并且生成HTML。

6.RMI/IIOP

RMI(Remote Method Invocation,远程方法调用)是Java的分布式对象标准,允许位于不同主机上的Java类之间进行通信。Java RMI是个应用程序编程接口(API),还是个分布对象模型;使用RMI,Java程序员可以像调用本地操作一样进行网络调用,从而很容易地构造分布式系统。IIOP协议本来是CORBA的一种传输协议,和RMI结合在一起,使得整合非Java对象变得更加简单。

7.Java IDL/CORBA

在Java IDL的支持下,开发人员可以将Java和CORBA集成在一起。他们可以创建Java对象并在CORBAORB中部署,或者创建 Java类作为和其他ORB一起部署的CORBA对象的客户。后者可用于遗留系统的集成。

8.XML(Extensible Markup Language)

XML是一种可以用来定义其他标记语言的语言。它被用来在不同的商务过程中共享数据。XML的发展和Java是相互独立的,但是,它和Java具有的相同目标正是平台独立性。Java和XML的组合构成一个完美的具有平台独立性的解决方案。

9.JavaMail

JavaMail是用于存取邮件服务器的API,它提供了一套邮件服务器的抽象类。JavaMail同时支持SMTP服务器和IMAP服务器。

10.JAF(JavaBeans Activation Framework,JavaBeans 激活框架)

JavaMail利用JAF来处理MIME编码的邮件附件。MIME的字节流可以被转换成Java对象,或者转换自Java对象。大多数应用不需要直接使用JAF。

11.JMS(Java Message Service)

JMS是用于和面向消息的中间件相互通信的应用程序接口(API)。它既支持点对点的域,又支持发布/订阅(publish/subscribe)类型的域,并且提供对下列类型的支持:经认可的消息传递、事务型消息的传递、一致性消息和具有持久性的订阅者支持。JMS还提供了与遗留后台系统集成的一种方式。

12.JTA(Java Transaction Architecture,Java事务构架)

JTA定义了一种标准的API,应用系统由此可以访问各种事务监控。

13.JTS(Java Transaction Service,Java事务服务)

JTS是CORBAOTS事务监控的基本实现。JTS规定了事务管理器的实现方式。该事务管理器是在高层支持 Java Transaction API(JTA)规范,在系统底层实现OMGOTS规范的Java映像。JTS事务管理器为应用服务器、资源管理器、独立的应用以及通信资源管理器等提供事务服务。

免责声明:本站所有文章内容,图片,视频等均是来源于用户投稿和互联网及文摘转载整编而成,不代表本站观点,不承担相关法律责任。其著作权各归其原作者或其出版社所有。如发现本站有涉嫌抄袭侵权/违法违规的内容,侵犯到您的权益,请在线联系站长,一经查实,本站将立刻删除。 本文来自网络,若有侵权,请联系删除,如若转载,请注明出处:https://yundeesoft.com/14493.html

(0)

相关推荐

发表回复

您的电子邮箱地址不会被公开。 必填项已用 * 标注

关注微信