欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  精华频道

JavaEE 快速开发框架 Wabacus 作者访谈

程序员文章站 2022-03-03 19:36:01
...
Wabacus是一个JavaEE快速开发框架,采用面向声明的开发模式,可以不用编程或极少编程即可实现复杂的数据展示、数据编辑、表单处理等功能,将JavaEE的开发效率提高5倍以上,代码减少60%以上。

JavaEE 快速开发框架 Wabacus 作者访谈


为了使大家对Wabacus框架有一个全面的了解,我们采访了该框架的作者

Wabacus官网:http://www.wabacus.org/

如果你在部署和使用Wabacus上有任何问题,可以与作者联系(QQ:349446658),或进入QQ 群:203873792、94291972、35530847进行讨论,还可以进入Wabacus论坛进行提问。

欢迎大家推荐更多开源项目给我们,支持中国的开源项目发展,如果您和您的团队希望展示创业理念和有趣之处,或者有朋友正在创造这样的价值,请联系我们,发站内短信给ITeye管理员或者发邮件到webmaster@iteye.com即可。


Wabacus是什么? JavaEE 快速开发框架 Wabacus 作者访谈

Wabacus是一个JavaEE快速开发框架,能快速实现完整的JavaEE功能,包括前台后台,因此与常见的框架jQuery、Extjs、Struts、Spring、Hibernate等不同,它们均只提供某一个方面的解决方案,开发人员必须组合使用它们才能完成JavaEE功能的开发。

另外,Wabacus与国内的很多快速开发平台也不同,国内很多快速开发平台只是对常用功能进行了一下封装,或者对简单基础代码进行了一下自动生成,并没有在开发思想这个层次上有什么改进,这种改变只能说是“物理变化”,而不是“化学变化”。

Wabacus则是在开发思想这个层次上进行改进,最大限度将开发人员从考虑“如何做”中解放出来,只需考虑做什么即可。因此与传统开发思想相比,相当于发生了“化学变化”,能成倍地提高JavaEE开发效率。

Wabacus所适用的领域,提供了哪些功能? JavaEE 快速开发框架 Wabacus 作者访谈

Wabacus是一个JavaEE快速开发框架,能适用于任意类型的JavaEE项目、产品及应用。不过由于前台展示采用的是JS/CSS/HTML等,因此也只适用于B/S结构的JavaEE项目,对于采用AWT/SWT等进行前台展示的C/S结构的项目则不适用。

Wabacus框架不仅从开发思想层面给开发人员带来了很大的好处,让他们尽量从“如何做”中解放出来,而且对常用且很多是很复杂的功能提供了良好的支持,让开发人员要开发这些功能时变得非常容易,只需简单声明即可,例如:

列过滤、列选择、冻结行列标题的报表、输入联想、文件上传/下载、行/列分组报表、树形表格、数据导入/导出、数据打印、交叉统计报表、主从报表、行排序等。

当然,Wabacus框架给开发人员带来的好处主要还是开发思想方面的根本改进,这个才是主要的,带来的好处也是巨大的。

开发这个框架的初衷,它与其它框架相比有什么优势? JavaEE 快速开发框架 Wabacus 作者访谈

本人从事JavaEE开发与架构将近9年的时间,后面大部分时间是负责公司各类项目、产品方面的架构设计,在这方面积累了较为丰富的经验,这个框架的思想也是多年架构经验的积累,用过在很多项目和产品中,取得了非常好的效果,凡是本人用这个思想设计的架构,在前期开发和后期维护方面都非常方便,新进来的开发人员能快速上手,后期的各种维护改造工作也很容易。

印象比较深的就是用这个思想开发的一个大型网站项目,在开发时,几个开发人员快速地配置了几百个数据展示功能,在后期维护差不多每年一次的改版中,这几百个数据展示功能也是最容易和方便改的,只要改几个JS/CSS文件以及少数的几个系统级配置文件就可以对它们的显示效果、显示结构进行整体调整。因此在项目组和客户方面都反映非常好。

正是基于这些项目、产品的成功实施经验,本人决定将这个思想转化为一个成熟的框架,让更多朋友受益,也改变一下国内开源框架原创性比较少的局面(比如国外搞IOC、AOP、O/R Mapping等方面的框架,国内很多朋友也是照着这些思想搞这些方面的框架,只是实现方式上进行一些改变,没有提出原创性的思想)。

关于和其它框架的比较,我认为Wabacus最大的优势就是开发思想的改进,将开发人员由传统的“面向过程”、“面向对象”思想中转入更容易、更高效的“面向声明”的思想中,大幅提高开发效率和降低开发复杂度。

代码减少60%,开发效率提升5倍以上,是如何实现的? JavaEE 快速开发框架 Wabacus 作者访谈

首先说明一下,这里说的“60%”、“5倍”都是一个概数,不是一个精确值,因为开发效率不能像性能一样,能通过工具准确定量测试,就好比问“交流时说话比打字快多少倍?”一样,我们也不能给出一个精确数,因为打字有快有慢,说话的语速也有快有慢,没办法精确说一定快多少倍,但我们知道整体上要快好几倍。

wabacus为什么能大幅减少代码量,成倍提高开发效率呢?原因就是它采用“面向声明”的开发思想,我们来介绍一下什么是“面向声明”的开发思想:

所谓“声明”,就是只要把要做的功能说出来,而不需开发人员考虑如何实现,具体如何实现交给Wabacus来完成,就好比“视频聊天”,只要把字说出来,而不需考虑如何写出这些字,就能表达自己的意思,因此比“写字聊天”、“打字聊天”的方式都要快很多倍,因为后两种方式都要考虑将字实现出来才能表达自己的意思,而传统的开发思想就好比“写字聊天”或“打字聊天”,要开发人员编写大量的代码将“字”实现出来。

使用wabacus开发,不仅大幅提高了开发效率,而且对开发人员的要求也比较低,因为不太需要关注实现,只需声明,就好比“视频聊天”一样,不需考虑将字写出来,因此文盲都能顺利地交流。

其实面向声明的开发思想也不是Wabacus独创,在很多框架中都有使用,而且都取得非常不错的效果。比如Spring,就是将对象的依赖关系做成可声明,提高对象依赖的灵活性和可维护性;再比如EJB或Spring,提供声明性事务,提高了事务控制的灵活性,减低了开发难度等等。但是它们只是着眼某一个方面,做的不够彻底,带来的改善是局部的。而Wabacus框架在更大的范围提供了声明性编程,尽量将用户的整体开发效率提到最高,所以它对JavaEE开发带来的好处是立体的,全方位的。

Wabacus扩展性如何? JavaEE 快速开发框架 Wabacus 作者访谈

Wabacus做为一个框架,需要满足各种复杂的场合,因此非常注重可扩展性,也提供了非常灵活的扩展接口,大体体现在如下方面:

  • 允许开发人员新增容器类型、报表/表单类型、数据类型、输入框类型,数据源类型等等,并允许用户在新增这些类型时,在配置文件中为这些类型新增自己的配置属性和配置标签。
  • 允许开发人员在拦截器的各拦截方法中控制报表/表单各个生命周期的行为,比如控制加载、保存的数据,阻止保存操作或者自己完成保存操作等等。
  • 允许开发人员在静态模板、动态模板中控制报表/表单的显示,并且可以在其中自己定制输入框。
Wabacus灵活的可扩展性源于它优雅的面向对象设计,看过Wabacus源码的,即使只看懂了一部分的朋友,都会对Wabacus的巧妙设计有着很深的印象。曾经有一个8年JavaEE开发经验的架构师,在研究Wabacus源码超过2个多月后对此有过高度评价。

Wabacus能否与其它框架共存在同一个项目中,比如在已有项目中加入Wabacus框架快速开发新功能? JavaEE 快速开发框架 Wabacus 作者访谈

Wabacus前台采用的是标准JS/CSS/HTML,后台采用的是标准Java实现,都没有用到其它框架,从它依赖的第三方jar包中可以看到,除了数据库驱动包,只有少数几个第三方组件,因此不会与任何现有的框架有冲突,可以与它们(比如常用的SSH、SSI等)共存在一个项目中。

现在使用框架的朋友中,有很大一部分都是在老项目中用Wabacus开发新功能,而之前用其它框架开发的功能要么保持不变,要么逐步迁移,运行时互不影响。

根据本人这么久的技术支持经验,很多朋友在用了Wabacus以后,虽然项目中可能还有其它框架,但有了新需求,第一时间想到的就是如何用Wabacus来实现,尽量避开其它框架,因为相比其它框架,Wabacus的开发效率高太多,只有当使用Wabacus不方便实现的时候,才会用其它框架开发。

Wabacus支持哪些数据库类型? JavaEE 快速开发框架 Wabacus 作者访谈

Wabacus内置了对SQL Server、Oracle、MySQL、DB2四种常用数据库的支持,每个数据库类型对应一个Provider类,比如Oracle数据库的Provider类为:com.wabacus.config.database.type.Oracle,MySQL的Provider类为:com.wabacus.config.database.type.MySql等等,如果要新增对其它数据库的支持,只要参照内置的数据库类型提供一个相应的Provider类即可。

早期没有完全开放源码,是什么原因? JavaEE 快速开发框架 Wabacus 作者访谈

Wabacus的源代码开放是逐步的,在早期,只公开了80%左右的Java源码,后面又开放了99%的源码,现在已经将所有Java源代码开放了。

早期没有开放所有源码是没有对所有朋友开放源码,但对正在使用框架的朋友还是开放了他们想修改的任意源码,也就是说他们想修改的源码如果没有在公开的80%或99%之中,他们是可以向我要的,我会发给他们,并教他们如何改。这样做的目的有两个:第一、鼓励大家使用框架;第二:早期版本不够稳定,我有可能会进行比较大的重构,因此如果让他们修改了太多源码的话,以后升级会非常困难。

不过现在Wabacus架构已经非常成熟,所有Java源代码都已经公开了。

你所知道的有哪些项目使用了该框架? JavaEE 快速开发框架 Wabacus 作者访谈

因为一般项目用了什么框架都是一个保密的内容,很多朋友不愿公开,尤其是外网能访问到的网站之类的项目更是这样,包括我自己用Wabacus的思想开发的大型门户网站,也不愿意公开说出是哪一家,所以很多使用Wabacus的用户我也不知道他们的项目名字,这里我列出一些愿意公开的项目:

  • 金昶网络科技电信增值业务平台
  • 哈尔滨市文化和新闻出版局办公系统
  • 实联化工业务支撑系统
  • 爱尔英语办公系统
  • 威海市*信通部门办公系统
  • 江苏无锡某银行营业网点业务支持系统、资金流监控系统
  • 哈尔滨工程大学综合评教系统
其他更多的项目可以从Wabacus的论坛上通过别人的提问看得到,不过那里只是一部分用户的发贴,还有很多是私下找我咨询,没有在论坛上发贴。

用户如何提交bug、参与贡献? JavaEE 快速开发框架 Wabacus 作者访谈

目前用户如果在使用过程中发现BUG,或者有需要改进的地方,都是通过在QQ或QQ群中联系我,然后我登记下来,尽早解决。此外,还可以通过在Wabacus论坛中登记BUG。

目前用户参与贡献都是进行比较外围的工作,比如录制视频、对新手进行技术支持、制作新的主题风格、提供DEMO演示服务器和论坛服务器、进行捐助等等,在框架开发上的贡献较少。

如果有朋友希望参与Wabacus框架的开发,可以开发IDE工具之类的,Wabacus的核心还是不希望太多人经手,担心搞乱,毕竟框架代码比较复杂。

作者简介 JavaEE 快速开发框架 Wabacus 作者访谈

本人吴星星(笔名),2003年毕业,一直从事JavaEE方面的开发与架构,开发的项目涉及银行、*、企业、证券等行业。对Java底层知识、面向对象的设计、可复用软件的设计非常感兴趣。

JavaEE 快速开发框架 Wabacus 作者访谈