admin 管理员组

文章数量: 1086019


2024年4月24日发(作者:sqlite怎么查看)

J2EE技术浅析

摘要:j2ee平台提供了一个多层结构的分布式应用程序模型,

该模型具有重要组件的能力,基于扩展标记语言(xml)的数据交

换,最适合于其商业和所需技术的产品组件,因此,有必要把j2ee

架构和核心技术简要阐述,以提高学习者的编程能力与企业人员的

业务水平。

关键词:j2ee web服务 ejb

一、j2ee介绍

j2ee核心是一组技术规范与指南,其中所包含的各类组件、服

务架构及技术层次,均有共通的标准及规格,让各种依循j2ee架

构的不同平台之间,存在良好的兼容性,解决过去企业后端使用的

信息产品彼此之间无法兼容,企业内部或外部难以互通的窘境。

目前,java 2平台有3个版本,它们是适用于小型设备和智能

卡的java 2平台micro版(java 2 p1atform micro edition,j2me)、

适用于桌面系统的java 2平台标准版(java 2 platform standard

edition,j2se)、适用于创建服务器应用程序和服务的java 2平

台企业版(java 2 platform enterprise edition,j2ee)。

1.j2ee的核心概述

j2ee是一种利用java 2平台来简化企业解决方案的开发、部署

和管理相关的复杂问题的体系结构。j2ee技术的基础就是核心java

平台或java 2平台的标准版,j2ee不仅巩固了标准版中的许多优

点,例如“编写一次、随处运行”的特性、方便存取数据库的jdbc

api、corba技术以及能够在internet应用中保护数据的安全模式

等等,同时还提供了对ejb(enterprise javabeans)、java servlets

api、jsp(java server pages)以及xml技术的全面支持。其最

终目的就是成为一个能够僚企业开发者大幅缩短投放市场时间的

体系结构。

2.j2ee中间件

j2ee体系结构提供中间层集成框架用来满足无需太多费用而又

需要高可用性、高可靠性以及可扩展性的应用的需求。通过提供统

一的开发平台,j2ee降低了开发多层应用的费用和复杂性,同时提

供对现有应用程序集成强有力支持,完全支持enterprse

javabeans,有良好的向导支持打包和部署应用,添加目录支持,

增强了安全机制,提高了性能。

二、j2ee架构概述

1.b/s多层体系结构

长久以来,c/s(客户端朋艮务器)两层结构在软件开发中广

泛应用,给人们带来相当的灵活性。近年来网络应用的快速普及,

以及业务处理要求的不断提高,c/s模式逐渐暴露出以下架构上的

缺陷。

(1)对客户端软件的维护问题.

(2)网络传输数据的准确性和稳定性问题.

(3)高负荷处理和平衡负载问题等。

2.j2ee三层架构

随着网络应用技术的成熟,针对这一系列的问题,基于多层框

架(三层或以上)的b/s(browser/server)结构应运而生。典

型情况下,由表示层、业务逻辑层和数据层各自独立组成所谓的“三

层架构”。其中,数据层又叫企业信息系统层、集成层或者持久化

层,本书从技术角度采用持久化层的称谓。j2ee架构设想的分布式

多层体系结构如图1所示。

图1多层体系结构

该体系的核心是ejb组件,ejb是j2ee分布式应用的核心,但

是一般的web应用并不要求实现分布式应用,因此可以使用其他途

径,如hibernate、jdo等对象关系映射(orm,object—relation

mapping)工具,或直接使用jdbcapl实现数据持久化。

(1)客户端只需符合要求的通用浏览器(比如某系统要求ie5.5

以上版本),就可以使用所有服务,节省了客户端软件安装和维护

成本,从而有效降低部署费用。

(2)客户端(其实是表示层组件,这里只为和c/s模式对比

理解)不再直接访问数据库,而通过中间业务逻辑层实现代理服务,

从而可以方便地进行数据库和业务逻辑组件进化,各层次组件之间

可以独立变化。

(3)多层结构可以方便地管理外部资源,各组件之间通过服务

接口互相协作,可以使用各种优化技术提高资源和服务的利用率,

典型的应用是资源池优化技术;

(4)错误和性能降低局部化,单独组件模块的错误和超载被最

大限度的限制在本模块内部,维持整体服务的可用性。

三、j2ee实现构架

3目前,在java web应用中的主流框架是sun的j2ee架构,本

章在业务逻辑层一节中探讨了j2ee多层分布式应用模型。j2ee对

持久层框架的实现提供了基本的实现架构如图2基本架构。可以看

到,持久性框架是一组软件服务,将应用与其使用和操作的数据源

分离,隐藏访问这些数据源的apl。这些apl组件包括jdbc、jdo

以及实体bean等。框架通过统一的dao组件封装这些具体的访问

逻辑。在各层次之间通过实现serializable接口的可序列化对象

(值对象或者数据传输对象等),传递对象化数据.本书的主题

struts框架位于顶端的表示层,它接受用户的输入和操作,传递请

求和数据给业务逻辑层,接收返回的结果呈现给用户界面。

图2 j2ee实现构架

1.ejb概述

ejb(enterprise javabean,企业级javabean)组件体系是j2ee

框架的核心组件之一,最初被设计为支持分布式对象计算,因此在

ejb2.0以前的版本中ejb组件只有远程接口,直到ejb2.0才因

为实际应用的需求,加入了本地接口。业界对ejb的评价主要源于

其复杂程度,ejb并不是一个好学好用的组件。

(1)使用ejb的正当理由:

a提供应用层组件的集群;

b提供与corba客户端的互操作:

c消费jms异步消息。

(2)可以考虑使用ejb的理由

a提供多线程解决方案;

b基于角色的访问权限控制;

c熟悉ejb架构。

2.ejb类型

(1)实体bean

实体bean是j2ee核心的持久化组件,代表存储在外部介质中

的持久化对象或者企业应用系统资源,它代表实体”,必须实现

javax.ejb.entitybean接口。简单地说,实体bean相当于数据

库信息,但二者并不等价。因此可以理解为——个对象关系映射,

不过这个对象关系映射身后有整个j2ee体系的支撑。

ejb2.0中,实体bean分为bmp和cmp。

bmp是bean--managed persistent’entity bean,中文就是bean

管理持久性实体bean,它需要开发者自己编写符合ejb编程规范的

实现代码,实现各种业务方法和管理方法,因此bean-managed就

是bean接口自己编写代码实现持久性管理。

cmp是container--managed persistent entity bean,中文容

器管理持久性实体bean,顾名思义就是开发者不用再自己编写代码

来实现持久性管理,借助集成开发工具甚至基本不用写代码。cmp

是ejb2.0增加的类型,有效地降低了系统开发的复杂程度,但是

在性能上比编写良好的bmp会稍有所下降。

(2)会话bean

会话bean分为有状态会话bean(stateless session bean)和

无状态会话bean(staeless session bean)两种,实现

javax.ejb.sessionbean接口。在应用中被用来完成一些业务操

作,因此它代表的是“动作”。不同的是,在有状态会话bean中可

以保存状态,而无状态会话bean不能。因此,同一个无状态会话

bean的实例之间完全相同,只能用来执行通用操作。而有状态会话

bean的实例各自带有不同的属性值,可以用来维持客户会话,典型

的应用是购物车。有状态会话bean的作用在一定程度上类似jsp

开发中常用的session。

(3)消息驱动bean

消息驱动bean(mdb,message driven bean)是ejb2.0增加

的类型,用来实现异步消息传递和处理机制,是实现jms(java

message service,java消息服务)的基础。jms提供了一组标准

的java apl实现消息递和处理。消息传递和处理有两种方式:队

列模型和机遇主题的发布/订阅机制。

队列模型是将消息对象放到消息队列中,监听该队列的消息驱

动bean取出消息进行处理,类似手机短信的形式(短信是消息对

象,手机短信信箱是消息队列,机主是消息驱动bean实例)。

发布/订阅机制则将消息分发给所有订阅者,类似生活中的报

刊订阅。

四、小结

j2ee是java的核心技术之一,是大型企业和高等院校计算机相

关专业学生所掌握的核心技术之一,是java web程序员必须在一

定程度上了解和掌握的知识。明白ejb的架构和类型,对科研人员

更好的掌握其内涵和原理有重要的理论价值和现实意义。

参考文献

[1]李刚.轻量级java ee企业应用实战.北京:电子工业出

版社,2008.

[2]郑阿奇.j2ee应用实践教程.北京:电子工业出版社,2009.

[3]杨中科.j2ee开发全程实录(附光盘).北京:清华大学

出版社,2007.

[4]蔡剑,景楠.java web应用开发.北京:清华大学出版社,

2005.

[5]王毅,周峰,孙更新编著.j2ee经典案例设计与实现.北

京:电子工业出版社,2007.

作者单位:

太原大学

(中北大学在读研究生)


本文标签: 组件 应用 实现 消息 技术