`

Java EE 6体系结构的变革

阅读更多

又看到 Reza 同学为 Java EE 6 奔走呼告了。如同在浩浩荡荡的就业大军中的一员, Reza 带着自己的最新“简历”—— Java EE 6 ,向咱们开发人员展示耳目一新的感觉。但从本文的字里行间中,隐隐约约还是能觉察到它的困惑和迷茫:“已经付出了这么多, Java EE 6 能再次成功吗?开发者会采纳它吗?如果不是,我们还应该做什么?......”。当年 EJB2.* 的垮台掀起了反对使用 EJB 的浪潮。实际上我接触 JavaEE 比较晚 ( 大概在 2007 年初 ) ,没有使用过 EJB2.* ,但也是不够客观的照着大家说的抨击 EJB ,天天嘴边挂着 Struts Spring Hibernate 。但随着对 JavaEE 的不断关注与了解,渐渐发现自己的盲从于无知。此次 Java EE 6 的特性预览更有让我渴望学习它的冲动。“技术选型的抉择政治因素往往大于技术本身 。” Java EE 6 的推广还应该要更多的成功实战项目来赢得“政治因素”。但如同刚毕业的应届生,没有经验也要面对就业,除实力本身外,靠的就是运气了......

 

本文希望你从技术的眼光看待 Java EE 6 的演化。下列资源也许对你了解本文有所帮助:

 

<!-- [if !supportLists]-->l         <!-- [endif]-->【翻译】 EJB3.1真的来了吗? EJB3.1系列文章 ( )

<!-- [if !supportLists]-->l         <!-- [endif]-->【翻译】 EJB3.1真的来了吗? EJB3.1系列文章 ( )

<!-- [if !supportLists]-->l         <!-- [endif]-->【翻译】 EJB3.1真的来了吗? EJB3.1系列文章 ( )

<!-- [if !supportLists]-->l         <!-- [endif]-->【翻译】 EJB3.1真的来了吗? EJB3.1系列文章 ( )

<!-- [if !supportLists]-->l         <!-- [endif]-->【翻译】 EJB3.1真的来了吗? EJB3.1系列文章 ( ) 终章

 

 

原文请看: http://www.theserverside.com/tt/articles/article.tss?l=JavaEE6Overview

 

 

讨论

 

我所在的 JSR 316 专家组,已经陆陆续续的在几个月内 Java EE 6 的细节公布出来了。本文的目的是想让你大致了解 Java EE 6 的改变,当然我们也鼓励你给我们更多的反馈。除在 JSR 316 专家组制定 Java EE 6 的工作外,我也会参与其它 JSR 的讨论。比如说 Java EE 6 平台已经发布了它的 公众审议草案,官方的公众审议将在 2 23 号结束。这意味着,这是最好的反馈时机。

 

 

简单回顾

 

Java EE 5 是一个相当成熟,布署广泛并且支持服务端友好开发的平台。 EJB 3.0 的引用已经颠覆了原有的业务组件开发模型,而原有 EJB2.x Entiy Bean 模型由持久层的 JPA 来代替。 JSF 也被作为官方的标准展示层框架,当然还有咱们的 JAX-WS 2.0 代替了 JAX-RPC 作为新的 SOAP web services API Java EE 5 的目标非常明确——通过引入 Annotation POJO 编程模型,零配置 (zero-configuration) 等一系列概念从而降低开发的复杂度,帮助开发人员从 XML 地狱中解脱出来。尽管对 Java EE 持观望态度的还是大有人在,但是也许要证明“实际上 Java EE 5 已经获得成功”的最有利的证据就是由于上述提到的种种改变,使得很多家伙第一次开口说他们已经考虑接受 Java EE 。还是这帮家伙,在体验 Java EE 编程模型后,不断的向我们反馈他们的震惊。

 

 

大局观

 

Java EE 6 又将是迈向理想中那简洁,高效以及整合完好平台之旅的一大步。 Java EE 6 又有了一系列技术上的革新:有全新的 WebBeans1.0 JAX-RS 1.1 API ,也有更加成熟的老牌 API Servlet3.0

 

除少数相对较小的改变外 ( 比如说标准的全局 JDNI 命名,本文将不会谈到 ) ,大多数 JSR 316 中的主题都是精挑细选出来的。现在咱们就一同来看看这些变化。想了解更多细节,我推荐你把公众审议草案下载下来看看。这是链接地址: http://jcp.org/en/jsr/detail?id=316 .

 

 

砍掉没用的 API

 

Java EE 的第一版发布于 1999 年。在竞争异常激烈的业界一直作为官方标准,那时间也不算很短了。但在这段时期里, Java EE 只是一味的在成长,结果导致到现在平台变得臃肿不堪,充斥着一堆毫无用处的过时 API ,用起来不爽,布署起来也不方便。 Java EE 6 开始正儿八经的处理这些 API ,确保平台更加轻量级,同时也是为了腾出更多的空间,更利于 Java EE 的健康成长。表 1 显示了那些被砍掉的 API ,当然原因我们也做出了说明:

 

 

被砍的 API

被砍原因

JAX-RPC

JAX-RPC 是早期通过 RPC 调用和 SOAP web services 进行交互的编程模型。由于 Web services 成熟后从 RPC 模型中分离出来,更加健壮,更多特性和流行 JAX-WS API 实际上已经代替了 JAX-RPC

 

EJB 2.x Entity Beans CMP

复杂,笨重,过度复杂的 EJB2.* Entity Bean 模型已经被 Java EE 5 的基于 POJO 的流行轻量级 JPA 持久层模型所代替。

 

JAXR

JAXR Java API 中少数几个用于 UDDI 注册服务的接口之一。遗憾的是,由于 UDDI 并没有广泛使用,现在 JAXR 已经几乎没有啥应用,而且供应商支持的也很少,难免遭到被砍命运。

 

Java EE Application Deployment (JSR-88)

JSR 88 是当初是用于 J2EE 应用程序在应用服务器上进行的配置和部署的标准 API 。可是该 API 始终没有得到众供应商的支持,不得不砍掉。

 

Java EE Management (JSR-77)

JSR 88 有着相似的命运, JSR77 原本是用于为应用服务器创建监控管理的 API 。可是各大供应商热情仍然并不高涨,难逃被砍命运。

 

1 Java EE 6 被砍的 API

 

 

上述精简 API 的原则上是,应用服务器供应商不需要强制的去支持这些技术,但是不排除一些大型的供应商仍就会对这些被砍 API 继续维持一段时期。

 

对于此次调整你有什么看法?太过于激进了?还是仍然过于保守?你还用上述表格中看得到的 API 吗?还有其它你认为也应该被砍掉的 API 吗?

 

 

Profiles: 为不同的开发人员提供不同的制定服务

 

对于 Java EE 主要抨击之一就是它太庞大了。确实啊,大多数中小型的 Java web 应用程序根本用不了所有 Java EE 技术 (full Java EE stack) 。你可以想像一下,如果要构建一个类似于 SOA 的应用程序,会用到消息,事务,持久化以及 Web Services ,但犯不着需要使用像 JSP JSF 这类的展示层技术。

 

Profile 就是为解决这个问题而设计的。 Profiles 其实就是一个 Java EE API 的子集,对于特定的应用程序有着各自的解决方案。比如说,被提议到的 Java EE Web Profile 仅仅只包含了一些最有可能大绝大多数 Java web 应用程序中使用的 API 。像 Profiles 这样的理念已经在标准化的世界上取得的成功也是由来已久。也许你早就知道, Java ME 其实就支持 Profiles ——支持每种特定的设备运行环境。类似的, Profiles 可用来更好的组织日益复杂的 web services 世界 ( 比如说 WS-I Basic Security Profile 等等 )

 

 

虽然 Java EE 6 通过 JSR 来定义了一些规则用于创建新的 Profiles ,但这一次仅仅只有一个 Profile 当选—— Web Profile 。表 2 列出了 Web Profile Java EE 完整平台的比较情况:

 

 

API

Web Profile

Full Profile

Servlet 3.0

<!-- [if gte vml 1]><v:shapetype id="_x0000_t75" coordsize="21600,21600" o:spt="75" o:preferrelative="t" path="m@4@5l@4@11@9@11@9@5xe" filled="f" stroked="f"> <v:stroke joinstyle="miter" /> <v:formulas> <v:f eqn="if lineDrawn pixelLineWidth 0" /> <v:f eqn="sum @0 1 0" /> <v:f eqn="sum 0 0 @1" /> <v:f eqn="prod @2 1 2" /> <v:f eqn="prod @3 21600 pixelWidth" /> <v:f eqn="prod @3 21600 pixelHeight" /> <v:f eqn="sum @0 0 1" /> <v:f eqn="prod @6 1 2" /> <v:f eqn="prod @7 21600 pixelWidth" /> <v:f eqn="sum @8 21600 0" /> <v:f eqn="prod @7 21600 pixelHeight" /> <v:f eqn="sum @10 21600 0" /> </v:formulas> <v:path o:extrusionok="f" gradientshapeok="t" o:connecttype="rect" /> <o:lock v:ext="edit" aspectratio="t" /> </v:shapetype><v:shape id="_x0000_i1025" type="#_x0000_t75" alt="" style="width:14.25pt; height:14.25pt" mce_style="width:14.25pt; height:14.25pt" /><![endif]--><!-- [if !vml]--> <!-- [endif]-->

<!-- [if gte vml 1]><v:shape id="_x0000_i1026" type="#_x0000_t75" alt="" style="width:14.25pt;height:14.25pt" mce_style="width:14.25pt;height:14.25pt" /><![endif]--><!-- [if !vml]--> <!-- [endif]-->

JSP 2.2

<!-- [if gte vml 1]><v:shape id="_x0000_i1027" type="#_x0000_t75" alt="" style="width:14.25pt;height:14.25pt" mce_style="width:14.25pt;height:14.25pt" /><![endif]--><!-- [if !vml]--> <!-- [endif]-->

<!-- [if gte vml 1]><v:shape id="_x0000_i1028" type="#_x0000_t75" alt="" style="width:14.25pt;height:14.25pt" mce_style="width:14.25pt;height:14.25pt" /><![endif]--><!-- [if !vml]--> <!-- [endif]-->

JSTL 1.2

<!-- [if gte vml 1]><v:shape id="_x0000_i1029" type="#_x0000_t75" alt="" style="width:14.25pt;height:14.25pt" mce_style="width:14.25pt;height:14.25pt" /><![endif]--><!-- [if !vml]--> <!-- [endif]-->

<!-- [if gte vml 1]><v:shape id="_x0000_i1030" type="#_x0000_t75" alt="" style="width:14.25pt;height:14.25pt" mce_style="width:14.25pt;height:14.25pt" /><![endif]--><!-- [if !vml]--> <!-- [endif]-->

EL 1.2

<!-- [if gte vml 1]><v:shape id="_x0000_i1031" type="#_x0000_t75" alt="" style="width:14.25pt;height:14.25pt" mce_style="width:14.25pt;height:14.25pt" /><![endif]--><!-- [if !vml]--> <!-- [endif]-->

<!-- [if gte vml 1]><v:shape id="_x0000_i1032" type="#_x0000_t75" alt="" style="width:14.25pt;height:14.25pt" mce_style="width:14.25pt;height:14.25pt" /><![endif]--><!-- [if !vml]--> <!-- [endif]-->

JSF 2.0

<!-- [if gte vml 1]><v:shape id="_x0000_i1033" type="#_x0000_t75" alt="" style="width:14.25pt;height:14.25pt" mce_style="width:14.25pt;height:14.25pt" /><![endif]--><!-- [if !vml]--> <!-- [endif]-->

支持

WebBeans 1.0 (?)

支持

支持

EJB 3.1 (Lite)

支持

支持

EJB 3.1 (Full)

 

支持

JPA 2.0

支持

支持

JTA 1.1

支持

支持

JMS 1.1

 

支持

JavaMail 1.4

 

支持

JAX-WS 2.2

 

支持

JAX-RS 1.1

 

支持

JAXB 2.2

 

支持

JACC 1.0

 

支持

JCA 1.6

 

支持

2 Java EE 6 Web Profile

 

 

WebBeans 为什么也能入围的原因曾经也是一个大大的问号,至今大家对是否应该在 Java EE 6 中加入 WebBeans 仍然各执一词。围绕 WebBeans 的争论焦点是:它怎么适合加入 Java EE 体系?还有是不是 JSR 所研究的技术就一定是对的呢?对于你是否也是这么想的呢?也许你并不了解 WebBeans ,下面我会对此话题进行延伸。是否 WebBeans 应该纳入到 Java EE 6 中呢?如果不这么做,那 JSR 应该做出什么样的改变?同时还应留心一下 EJB Lite ,它是虽不是完整版的 EJB ,但此次也被加入到 Web Profile 中了。下面我也会简要的再提到 EJB Lite

 

对于 Java EE Profiles 思想,你又有何看法?符合 Profile 的轻量级的应用程序服务器是否对你有用?关于 Web Profile 所涉及到的技术你又怎么看?是内容太少了,太多了,还是刚刚好?光有它就足够了,还是需要在 Java EE 6 中定义其它 Profile ?还是咱们应当考虑一下更简化的“ Java EE Basic Profile ”?

 

 

快速预览 Java EE 6 体系

 

现在我们来来看看 JSR316 专家组所做的工作,看看哪些技术加入到了 Java EE 平台上了。虽然这项工作非常重要并且我们也渴望听到你对上文提到的内容提出建议。从这一章节开始,我们来快速看看 Java EE 6 API 的改变。我是极力推荐你自己去深度发掘下列所提到的每一项 API 。我认为你会喜欢接来的内容,所有的 API 都会因你时宜的反馈而更加精彩。

 

 

WebBeans 1.0

 

Java EE 6 的里程碑上, WebBeans 也许算得上是最具开创性的 API 了。 WebBeans 填补了 Java EE 的很多空白。尽管 WebBeans Seam Google Guice 以及 Spring 所进化而来,但它并不是直接的复制。实际上, WebBeans 本身就拥有许多独一无二的创新。 WebBeans JBoss/Red Hat Gaving King Google Bob Lee 领导着。下面就对 WebBeans 的特点进行简要概括说明:

 

<!-- [if !supportLists]-->l         <!-- [endif]-->WebBeans JSF JPA EJB3 等编程模型统一了起来,让人感觉它们是一个整合完好的开发平台。这一切是通过将 EJB3 beans JPA entity 以及普通 Java Bean 注册为 WebBeans 的组件,然后通过使用 EL 表达式进行访问。当然,它们之间也可以在进行“依赖注入”。实际上,如果你需要的话, WebBeans 完全可以让你忽略 JSF backing beans

 

<!-- [if !supportLists]-->l         <!-- [endif]-->通常在上下文中, WebBeans 隐式的管理着所有注册组件的生命周期。除传统的 request, session application 等主要作用域外,它还添加了一些新作用域“ dependent ”和“ conversation ”。 dependent 显式的“继承”了调用者的作用域,而 conversation 则是一个全新的作用域,( conversation 上下文与一个浏览器窗口(或页卡)联系在一起,这个浏览器窗口(或页卡)由随每个请求提交的一个标志来标识。 conversation 作用域使用 HTTP Session 的一个单独的区段在页面之间迁移数据 )从 EJB3.1 来看,它又填补了客户端组件作用域 ( 包括 stateless stateful shared) Web 应用程序中心端的空白。

 

<!-- [if !supportLists]-->l         <!-- [endif]-->WebBeans 为大家引入一组成熟的依赖注入特性,提供了一个完整的以 Java 为中心的类型安全开发平台。这些特性包括:对任意非 EJB Java 对象的整合,将非托管的对象注入到托管对象中去,使用对象工厂,指定组件化的布署环境并利用 stereotypes 去管理 annotations

 

<!-- [if !supportLists]-->l         <!-- [endif]-->WebBeans 可以通过 Annotation 将拦截器 (interceptor) 绑定到目标对象上,增强了 Java EE 的拦截器模型。通过 Annotation 所绑定的拦截器会自动的作用于目标对象,这一点与现在的 Java EE 5 是不同的( Java EE 5 中目标对象与拦截器之间还是通过间接方式进行关联,比如说 xml 配置文件)。

 

 

列出的这些令人印象深刻的特性还只是 WebBeans 的冰山一角。 WebBeans 增加了许多其它非常棒的特性来制定下一代 Java EE 的整合方案。想更近一步了解 WebBeans 吗,请点击下面链接去下载已经 公开草案吧: http://jcp.org/en/jsr/detail?id=299 .

 

 

 

呵呵,已经超过文本最大字数了,点击此处继

分享到:
评论

相关推荐

    Java EE知识体系结构

    Java EE知识体系结构,用图解的形式详细讲述了Java EE整体的知识架构。

    Java EE 6 tutorial

    Java EE 6(Java Platform, Enterprise Edition 6)是Java技术在企业级开发中的一个里程碑,它为构建可扩展、高性能、分布式的企业级应用程序提供了全面的框架和规范。本教程由Sun Microsystems(后被Oracle收购)...

    The Java EE 6 Tutorial

    《Java EE 6 教程》是Oracle公司于2010年发布的一部详尽指导书籍,旨在帮助开发者深入理解和掌握Java Platform, Enterprise Edition(Java EE)平台的应用开发技术。Java EE 6作为企业级应用开发的标准框架,提供了...

    JAVA EE体系结构图

    基于MVC模式的java体系结构图,视图包括html,css,div,ajaxflash,javascript,xml,jsf,tag,控制器包括JSP,SERVLET。

    java ee 6 with glassfish 3

    Java EE 6(Java Platform, Enterprise Edition)是Java开发企业级应用的标准框架,它提供了丰富的API和服务,用于构建分布式、多层的企业系统。GlassFish 3是Oracle公司推出的开源应用服务器,是Java EE 6规范的...

    Java EE 6 规范手册中英文 chm

    Java EE(Enterprise Edition)6是Java平台上用于构建企业级分布式应用程序的标准框架。它提供了一系列的API和服务,使得开发者能够创建高效、可扩展且模块化的Web应用程序。本规范手册包含了Java EE 6的所有核心...

    JAVA EE 6 api

    这是官方的英文版的JAVA EE 6的API,带索引功能的。

    Java EE期末考试试题

    Java EE,全称为Java Platform, Enterprise Edition,是Java平台下的企业版,主要用于构建分布式、多层的企业级应用程序。它提供了一系列的API和服务,包括Servlet、JSP、EJB(Enterprise JavaBeans)、JMS(Java ...

    JAVA EE 6 jar包集合

    Java EE 6,全称Java Platform, Enterprise Edition 6,是Java平台上用于构建企业级Web应用的标准框架。这个集合包含了开发Java EE 6应用程序所需的各种jar包,方便开发者直接使用,无需逐一寻找和下载。Java EE 6的...

    Java EE 7 Developer Handbook.pdf

    《Java EE 7 Developer Handbook》在结构上可能包含了以下知识点,因为这些通常是Java EE开发者需要掌握的核心内容: 1. Java EE 7核心概念:介绍Java EE 7的基础架构和核心组件,包括其各个组成部分(如Servlets, ...

    Beginning Java EE 6 with GlassFish 3, 2nd Edition

    ### 关于《Beginning Java EE 6 with GlassFish 3, 2nd Edition》的知识点解析 #### 一、Java EE 6 平台概述 **Java Enterprise Edition (Java EE)** 是Oracle公司(前身为Sun Microsystems)开发的一个企业级Java...

    《Java EE 6基本概念》文字版[PDF]

    在Java EE 6的教程:基本概念,四版,是一个任务导向,例如驱动的指南为Java平台企业版6(Java EE 6中)开发企业应用程序。由甲骨文的Java EE 6日团队成员的书面文件,这本书为我们提供了新的平台的深刻理解和中级...

    java-EE-API.zip_Java ee api_java ee 6 api

    这个压缩包"java-EE-API.zip"包含了Java EE 6的API规范文档,这对于开发者理解和使用该版本的API至关重要。 首先,Java EE 6 API的核心目标是提供一组标准接口和服务,让开发者可以构建可扩展、健壮且安全的Web应用...

    java ee基础使用教程

    Java EE(Java Platform, Enterprise Edition)是Java平台上用于构建企业级Web应用的框架集合,它提供了丰富的服务和组件,使得开发者能够快速开发出分布式、多层架构的应用程序。本教程由知名讲师郑阿奇编著,旨在...

    Java EE 6 DOC API (html版,英文完整)

    Java EE 6(Java Platform, Enterprise Edition 6)是Java平台的一个重要版本,专注于企业级应用的开发。这个API文档提供了全面的技术规范和接口参考,是开发者理解和使用Java EE 6框架的重要参考资料。以下是该文档...

    myeclipse中java EE 6 的jar包全

    Java EE 6,全称Java Platform, Enterprise Edition 6,是Java平台上用于构建企业级应用程序的一个版本。这个版本引入了许多新特性和改进,旨在简化开发流程、提高可维护性,并加强了对Web服务和轻量级框架的支持。...

    Java EE架构师认证指南

    Java EE 架构师需要了解什么是体系结构、架构是角色、服务级别需求等概念。体系结构是指一个企业或组织中的软件架构,它描述了软件系统的结构、组件、关系和交互方式。 Java EE 概述 Java EE 是一个基于 Java 的...

    java ee 5 及java ee 6

    Java EE 5 和 Java EE 6 是两个重要的版本,分别于2006年和2009年发布,它们在Java EE发展历程中起到了关键的推动作用。 Java EE 5 的主要改进和特性包括: 1. **简化编程模型**:Java EE 5 引入了注解...

    《Java EE 6权威指南 第4版 基础篇》.((美)Eric Jendrock).PDF

    《Java EE 6权威指南 第4版 基础篇》是Java企业级应用开发的一本经典著作,由美国作者Eric Jendrock撰写。这本书详细介绍了Java Enterprise Edition 6(简称Java EE 6)的核心技术和最佳实践,为开发者提供了全面且...

Global site tag (gtag.js) - Google Analytics