站内搜索: 请输入搜索关键词

当前页面: 开发资料首页J2EE 专题J2ee与ASP.NET平台电子企业的两种构想(4)

J2ee与ASP.NET平台电子企业的两种构想(4)

摘要: JAVA,EJB,J2EE,ASP,ASP.NET

J2EE体系结构<?xml:namespace prefix = o ns = "urn:schemas-microsoft-com:office:office" />

与.NET平台相比,Sun公司的标准定义的J2EE体系结构有很少可以讨论的空间,因为就没有什么可讨论的。如果一个人注意某个具体开发商的产品,如IBM公司的WebSphere,那么就会看到其技术的最大的一部分是WebSphere专用的。比较所有开发商对J2EE的具体改进,已经超出了本文的范围,在我的经验中,大多数对J2EE作为一个平台感兴趣的公司对该标准的可移值性感兴趣。任何对可移值性感兴趣的人都会需要将他们自己局限于Sun公司所定义的标准。

J2EE体系结构可以被分为5部分:

最后一部分,非程序员可见API,包括定义了如何将其他产品插入到J2EE中的API,如连接器API,以及J2EE模型中被最近的改进有效替代的API,如JTA(Java Transaction API)。由于从比较微软和Sun公司计划的角度来说,非程序员可见API并不重要,因此在笔者的概述中将不涉及这些方面 (就如同笔者在.NET平台概述中并没有涉及功能相当的API一样)。

Java语言系统

在高层次上,Java语言系统看起来与.NET Framework类似。在这两种情况中,源代码都是被翻译成一种中间语言。但是,在.NET平台中,这种中间语言是MSIL,而在Java系统中,是Java Byte Code。在这两种情况中,中间语言被带入到运行环境中。在Framework中,运行环境是Common Language Runtime。对于Java,运行环境是Java虚拟机(Java Virtual Machine)。总体而言,Common Language Runtime和Java虚拟机有类似的功能,并且在技术进步方面,都无可置疑地在发展和彼此交互跃进。

这两种系统之间最重要的区别与源代码到中间语言的翻译有关。在.NET平台中,中间语言设计用来适应各种语言的需求。在Java中,中间语言设计用来满足Java的需求。虽然从理论上,从除Java外的语言生成Java Byte Code是可能的,但是实际上这还没有在任何一种商业产品中证明。

客户端程序设计模型

J2EE客户端程序设计模型重点集中在与浏览器的交互上。客户端程序设计模型有3部分:Java Applets,Java Servlets和Java Server Pages。

Java Applets用来对在浏览器内运行的Java代码进行打包。在.NET平台空间中,这在功能上与ActiveX相当。在笔者的经验中,applets或ActiveX组件使用的相对较少。电子商务体系结构一般都是以向表示层发出请求的浏览器为基础,然后表示层使用HTML页面进行响应。这种系统并没有使用ActiveX或Java Applets,因此笔者在本白皮书中并没有讨论这些技术的任何一种。

处理HTTP请求和HTML响应的重要技术是Java Servlets[1]和Java Server Pages[2]。这两种技术与微软空间中的ASP.NET(Active Server Pages)类似。

.NET平台与Java表示层中间的主要区别在于处理不同的客户端功能的方式。Java表示层沿用了以前的Microsoft ASP (pre .NET)模型,它使得表示层程序员的责任是决定最终的目的浏览器(或其他瘦客户端系统),瘦客户端系统的功能,以及如何生成HTML来充分发挥瘦客户端系统的优势。

中间层基础结构

对于J2EE,中间层基础结构是Enterprise Java Beans (EJB)。该规范的当前版本是2.0,可以从网上获得[3]。与J2EE相当的.NET平台是COM+。

在EJB和COM+之间,体系结构的差别非常少。这两种体系结构本质上是从MTS(Microsoft Transaction Server)派生出来的,是由微软公司在1996年引入的最初的面向组件的中间层基础结构。由MTS最先引入,然后合并到EJB和COM+中的重要想法包括:

EJB加入了一种新的体系结构想法,一项自动管理组件状态的技术。这项技术被称为entity beans(实体豆)。虽然这种想法具有吸引力,但是当前的实施却依赖于独立于数据库缓存的中间层数据缓存。很不幸的是,在这两种缓存之间没有保持一致性的机制。这意味着对实体豆的任何使用都会带来数据库损坏的高风险。在缓存一致性问题解决之前,在最佳试验技术方面,必须得不断考虑实体豆技术。

要连接EJB和COM+的深入比较,请参阅笔者最近的著作[4]

程序员企业级API

我们调用Java Enterprise API 时的最重要部分如下:

J2EE:将一切合并到一起

图 4 显示了J2EE主要部分之间的关系,可以将其与图3和和图1进行比较。图3显示了.NET平台的相当的形象描述,图1中显示了相当的一般体系结构。



[1]Java Servlet 1.2规范可以在http://java.sun.com/products/servlets获得。

[2] Java Server Page 1.2规范可以在http://java.sun.com/products/jsp获得。

[3] 请参阅http://java.sun.com/products/ejb/docs.html。

[4]COM+ and the Battle for the Middle TierRoger Sessions著,John Wiley and Sons2000年1月发行

[5] 说明书可以在http://java.sun.com/products/jdbc得到。

[6] 说明书可以在http://java.sun.com/products/jndi得到。

[7] 说明书可以在http://java.sun.com/products/jms得到。



↑返回目录
前一篇: J2ee与ASP.NET平台电子企业的两种构想(6)
后一篇: J2EE 全面简介