概述
weblogic workshop 8.1包括了一个应用框架和一个ide来支持使用页面流、控件和带注释的web服务开发企业应用程序。本文将介绍workshop 8.1运行时与apache beehive项目之间的一些区别。
社区的变化
自从2003年weblogic workshop 8.1应用框架发布以来,它已经经历了重大的变化。更值得注意的是,bea将该框架作为蜂巢计划(beehive)捐献给了apache软件基金会。这是在2004年5月宣布的,此后,beehive就一直处于apache孵化器中,直到2005年8月它成为一个顶级apache项目。这意味着其代码、社区、bug、开发流程以及项目的未来现在都对整个企业java社区公开了。然而,变化并未结束,因为与此同时beehive也已经获得了巨大的技术进步。
技术的发展
与workshop 8.1相比,beehive框架中的技术已经发生了重大变化。现在beehive控件包含在一个更为轻量级、更易于测试且更灵活的容器中,而仍然保持了一个简单的元数据驱动的用户模型。netui具有更丰富的特性,而且由于在编程模型和表示层所做的改进,它也更易于配置了。从workshop 8.1到beehive最为明显的变化可能是从javadoc元数据标签到与标准兼容的java 5.0注释的转换。接下来,我们将深入探讨beehive的每一部分。
controls
beehive中的controls框架是一个更为通用的元数据驱动的pojo框架。该框架被分为两部分――一个核心框架,它支持开发基于javabean的注释,以及一组系统控件和服务,用于特化核心框架以抽象对jdbc数据源、jms队列和ejb之类的j2ee资源以及事务和安全性服务的访问。
workshop 8.1控件运行在ejb容器内部,而controls核心框架不再依赖于j2ee。该框架还可以在j2ee容器外进行测试,这意味着可以无需启动应用容器而对业务逻辑和资源访问进行单元测试。
controls核心框架支持一个控件接口与其一个或多个实现之间的松散耦合――可以动态地将一个实现绑定到接口上。此外,现在可以在运行时重写应用于控件的元数据,以便更轻松地配置控件在不同的环境中执行。例如,可以通过这个可插入的元数据机制,在运行时重写数据库控件的jndi数据源名称。
控件的实例化可以使用声明式(使用@control注释)和编程式(使用javabean api调用)的方式。控件甚至可以通过标签用于jsp容器中。在beehive中,控件方法既不是隐式进行处理也不是隐式进行保护的。这些功能可由开发人员根据需要添加。
系统控件
系统控件是对controls核心框架的扩展,它们提供了对各种j2ee技术的抽象,包括ejb、jms和jdbc。如果您熟悉workshop 8.1中的内置控件,您就很可能会熟悉它们在beehive中的后继者。
例如,beehive数据库控件仍然对方法设置了一个包含对方法参数的动态绑定的sql语句,并映射结果集到返回类型,但是现在又新增了一些其他的特性,比如可插入的结果集映射、批量更新、生成键的检索、容器外测试等等。
netui和页面流
netui中的页面流和ui框架也得到了发展。页面流支持许多新特性,包括:
- 声明式验证(通过jakarta的commons validator)
- struts tiles
- 可以将任意javabean用作动作表单,并支持对这些表单的验证
- 页面流基类和可继承的元数据
- javascript 弹出窗口
- 与javaserver faces(作为ui显示技术)集成
页面流与控件之间的架构差异也得到了调整,以便控件可以包含在页面流内部,就像包含在web服务内部一样。例如,当beehive数据库控件向页面流返回一个jdbc结果集,结果集不会被关闭。
其用户界面技术,即netui jsp标签,现在支持可验证的html 4.01和xhtml 1.0 transitional / strict呈现。jsp 2.0表示语言几乎被所有的jsp标签属性用于数据绑定。这向netui标签用户公开了jsp 2.0容器的表示语言、隐式对象以及jsp函数的全部功能。新增了一个数据网格,它呈现随机的数据集,比如对象数组、xmlbean、行集和结果集。该数据网格还支持一个灵活的排序、筛选和分页模型。还有一个新增的支持ajax的html树。
项目模型和项目构建
beehive中的另一个重要变化是项目模型――没有了!beehive源文件只是带注释的java 5.0,而没有任何定制的文件扩展,是纯粹的java。框架没有对使用它的项目的结构做任何假设,它可以用于构建web应用程序、web服务、企业应用程序,甚至是可以在java swing应用程序内部运行的控件。beehive还提供了一组ant 1.6 宏指令,用于构建控件和页面流,这些宏指令可以随机组合以支持任一种结构的项目。最后,构建支持beehive的应用程序只需要java 5.0 jdk中可用的工具而不需要使用ide。虽然如此,使用eclipse以及其他工具无疑会使开发工作更轻松。
测试
beehive的一些源工件也可以在应用容器外进行测试。在workshop 8.1框架中,使用控件进行测试驱动的开发是一个挑战,因为这需要应用容器以及集成到ejb的测试框架。现在,可以使用junit测试容器对beehive控件进行测试,该容器的运行不需要应用服务器,并将随该框架的下一个版本配送。
结束语
希望本文能够使您了解到workshop 8.1框架是如何发展成为apache beehive的。本文所描述的一些变化突出说明了beehive中的一些重大改进,当然了,还有更多的其他新特性值得一看。
也许最为重要的是,其社区和代码现在是开放的。apache beehive社区欢迎大家参与开发该项目。最好的参与方式是订阅我们的邮件列表,下载 beehive 1.0,构建一个应用程序并向我们反馈。有关参与的更多信息可在此找到。
闽公网安备 35060202000074号