野心勃勃的 Web Beans( 中篇 ) 1. Seam为Web Beans铺路 Seam是JBoss的拳头产品之一,与Hibernat" name="description" />

JBoss野心勃勃的Web Beans(下篇)

发表于:2007-06-11来源:作者:点击数: 标签:
相关文章链接: JBoss野心勃勃的Web Beans(上篇) JBoss MI LY: 宋体; mso-ascii-font-family: 'Times New Roman'; mso-hansi-font-family: 'Times New Roman'"> 野心勃勃的 Web Beans( 中篇 ) 1. Seam为Web Beans铺路 Seam是JBoss的拳头产品之一,与Hibernat

相关文章链接:

JBoss野心勃勃的Web Beans(上篇)                    JBossMILY: 宋体; mso-ascii-font-family: 'Times New Roman'; mso-hansi-font-family: 'Times New Roman'">野心勃勃的Web Beans(中篇) 

1. Seam为Web Beans铺路

Seam是JBoss的拳头产品之一,与Hibernate有着同等重要的地位。JBoss Seam是一个功能强大的Web应用框架,Seam的英文含义是“缝合”的意思,正如Seam的名字所暗示的那样,Seam是一瓶极具粘合力的技术缝合剂,能够将Ajax、JSF、EJB3、Portlet以及Business Process Management (BPM)等诸多技术缝合在一起。Seam的剑锋直指下一代的Web2.0应用,而它所统一和集成的这些技术,正是Web2.0所必须的。 

Seam的使命是降低Java应用的复杂度,不但从架构级,而且深入到API级别。在Seam看来,复杂的Web应用,可以通过一些简单组件的组合来实现,这些组件包括经过注释的POJO,用户界面组件或JavaScript部件,以及少量的XML。

组件模型是Seam的核心,在Seam里面,什么都是组件。这不奇怪,随着面向对象思想的深入人心,组件模型早已成为软件编程的不二选择,不过,Seam的组件模型有其出人意表之处,那就是Seam打破了传统编程理论中,表示层组件和应用逻辑组件之间牢不可破的界线,将表示层组件模型和应用层组件模型,合而为一。Seam的这一做法是一面双刃剑,一方面,对于小规模应用,两个组件模型界线的模糊化,显然简化了应用框架的格局,降低了编程的复杂度,但另一方面,表示层和应用层的融合,与现代分层理论和实践相违背,是否适用于大规模复杂应用,有待实际项目的考验。

两种框架经Seam缝合之后,在Seam里面运用组件就非常容易了。简单的POJO自然不在话下,即使是EJB,由于EJB3已经通过注释技术,将EJB从重量级、粗粒度的对象,转变成了轻量级、细粒度的对象,在Seam里面的运用也是轻而易举的。当然,Seam的用途并不局限于EJB3,Seam可以用在任何J2EE环境中,甚至在简单的Tomcat中,Seam也能找到用武之地。这得益于Seam的API级别的基础框架。

在Seam之前,HTTP Session是Web应用状态管理的唯一手段,Seam改变了这种状况。Seam提供了多种不同粒度的上下文状态,其范围涵盖从对话级别到业务流程级别,将程序员从HTTP Session的局限性中解脱出来。例如,Seam可以编写支持多浏览器窗口的Web应用,就像桌面环境下的多窗口应用一样。

此外,Seam集成了JBoss的jBPM,即JBoss业务流程管理,使得Seam具备了实现和优化复杂的工作流和页面流的能力。

在可测试性方面,由于Seam的组件都是POJO,因此,对Seam应用实施单元测试,是非常容易的。不过,对于复杂应用,单纯依赖单元测试是不够的,因此,Seam在其框架的核心特性中,提供了对测试的支持能力,这使Seam获得了良好的可测试性。Seam的开发人员可以编写JUnit或TestNG测试,完整地模拟系统和用户的交互过程,这样就可以在IDE内,完成系统所有组件的测试。

Seam的最新版本是1.1版,和它的前一个版本(Seam 1.0版)相比,1.1版的Seam最大的卖点是Ajax。Seam集成了基于JSF的若干开源Ajax方案,例如ICEfaces和Ajax4JSF等。由于对Ajax功能的集成利用了Seam独特的状态和并发管理引擎,开发者无需学习JavaScript,就能替应用涂上Ajax的油彩。

2. Web Beans信心十足

从上面对Seam的介绍,可以看出Seam与Web Beans几乎完全类似,事实上,Seam正是Web Beans的前身,只不过Seam是JBoss自己鱼缸里的一条大鱼,而Web Beans则是JBoss投向Java棋盘的一枚棋子。Web Beans试图收获的果实,JBoss已经在Seam这块试验田里播下了种子。这正是Gavin King信心的来源,是Gavin King敢于夸下海口的原因。这一点,从Seam和Web Beans在时间上的前后呼应,也可以看出。Seam 1.0的发布时间是2006年6月,而此时距离Gavin King抛出JSR 299不足一个月,也就是说,在Seam发布前不到一个月,当JBoss的Seam项目刚刚结束内部发布,准备推向公众之时,Gavin King看到了Web Beans的目标是可以达成的,所以毅然提交了Web Beans的JSR。

Seam和Web Beans在时间上的重叠,绝非巧合,就连Gavin King自己,也承认Seam和Web Beans承前启后的关系。在提交给SE/EE执行委员会的申请中,Gavin King解释Web Beans现有的技术基础时,提到了JBoss的Seam。Gavin King认为,Seam揭示了Web Beans某些技术问题的一种可能的解决方案,并且Seam表明这些方案在原理上是可行的。

3. JBoss的野心

现在,让我们来看看,如果Web Beans成功了,Java Web企业应用框架,会是怎样一种格局呢?如前所述,从下到上,Java Web企业应用由三个层构成。最底层是数据层,中间是应用层,最上面是表示层,而粘合这三个层的,是JBoss的Hibernate和Web Beans。我们不妨稍做分析:数据层是关系数据库的世袭领地,在下一代面向对象数据库出现之前,关系数据库的地位固若金汤,不会有什么变动;表示层不如数据层那么风平浪静,但Sun的JSF因其创新性的引入了组件模型的概念,成为众多框架中出类拔萃者,未来无疑是JSF的;应用层可以说是最动荡不安的区域,Sun的EJB过去有着一段失败的历史,现在虽然以全新面目推出了EJB3,但EJB的未来仍有很多未知数。所以,如果说Java Web企业应用框架会发生一些事情的话,应用层将会是主要战场。

如果上面的分析是正确的,那么,JBoss在应用层框架之役上,已经占据了相当有利的地形。应用层的下面有Hibernate虎视眈眈,上面则埋伏着Web Beans的十万大军,JBoss之手,如同一把钳子,牢牢地控制着应用层框架。处于Hibernate和Web Beans夹击之下的应用层框架,完全落入JBoss掌中,并非不可能。只需将Hibernate的触角向上延伸,配合Web Beans的向下渗透,JBoss想要吞并应用层框架,比任何其他对手的胜算都要大一些。

JBoss是Java开源领域的一个传奇企业,以一个开源的应用服务器JBoss起家,现在已经是开源领域最活跃的力量之一了。Hibernate和Gavin King的加盟,是JBoss发展道路上举足轻重的事件。Hibernate是JBoss梦寐以求的,Gavin King也需要一个相对稳定收入和环境,来支撑Hibernate的开发,所以,二者一拍即合。一家传奇企业与一个传奇人物走到了一起,如果不继续制造一些传奇的产品,那倒奇怪了。Seam的身体里流淌着JBoss和Gavin King的血液,脱胎于Seam的Web Beans,是否也会在Java Web企业应用框架的历史上,写下一段传奇的经历呢?

被Red Hat以3.5亿美金的巨资收购后,JBoss迎来了企业发展的第二个春天,有Red Hat做靠山,JBoss在IBM、Sun和Oracle这些巨人面前,多少鼓起了一些抬头正视的勇气。JBoss的脾气,一如它的创始人Fleury,坚定而固执,在Bea的WebLogic和IBM的WebSphere大收其费时,JBoss“顽固地”坚持走自己开源和免费的道路,终于在应用服务器市场上占据了一席之地,并且获得丰厚回报。精神和物资,是迈向成功的两大基石,Red Hat的雄厚财力、Fleury的坚定信念以及Gavin King的不凡勇气,或助Web Bean成功闯关,成就JBoss在Java Web企业应用框架领域的勃勃野心。

(责任编辑 火凤凰 sunsj@51cto.com  TEL:(010)68476636-8007)



原文转自:http://www.ltesting.net

评论列表(网友评论仅供网友表达个人看法,并不表明本站同意其观点或证实其描述)
...