CUBA Platform

 开源的、可靠的企业级应用开发利器

原文

翻译:CUBA China                                                         

CUBA-Platform 官方网站:

CUBA China 官方网站:

前言

        

        CUBA China是由多名具有丰富的行业软件、工具软件开发经验的开发人员组成的团队,我们出于对CUBA-Platform开发技术的共同爱好而成立, 我们的初衷是建立一个社区、与更多的行业软件开发人员一起交流关于CUBA-Platform及企业级应用的开始技术、架构经验等。

  作为企业软件开发行业的“老兵”,我们经历过众多的开发框架,包括国内的、国外的,我们每个人对于所使用过的框架都持有种种不满意,但CUBA-Platform的整体表现让我们印象深刻,她具有深厚的技术沉淀(GITHUB上自2009年起有代码提交)、源自实践的设计、丰富的文档、开放的姿态、先进的技术栈、完备的企业软件基础功能、高度可定制的系统架构、开发工具加持等等,所有这些让我们认为她是一个值得投入的框架。

  独乐乐不如众乐乐,所以我们计划构建并维护一个中国地区CUBA-Platform的社区,为国内的企业应用开发人员提供关于CUBA-Platform及企业级应用的技术交流、讨论的平台。

  这篇文章是我们介绍CUBA-Platform的第一篇文章,后续我们会持续推出一系列翻译或原创文章。 如果您希望进一步了解CUBA-Platform并及时获得最新的技术文章,请扫描文章右侧或下方的二维码关注我们的公众号。

图片8.png

摘要

       本文CUBA-Platform简介 一个结合了可靠架构企业应用程序必备功能和应用程序快速开发工具的开源框架。

为什么需要开发框架

       从进入计算机时代,企业应用软件开发一直面临一个挑战:虽然企业应用开发的目的是解决实际业务问题,但事实上开发人员必须花费大量时间和精力在纯技术层面比如软件架构和一些很通用功能。

       为了解决上述技术与业务之间的不对等精力消耗,涌现了很多开发框架,目的都是为了提高抽象级别,将开发人员从低级繁杂的工作解放出来。随着时间的推移,这些开发工具越来越智能,使得开发效率越来越高Borland Delphi就是21世纪初最成功的例子之一,它能使开发产出大幅提升。

       过去的十年以来, 企业级应用软件的需求越来越多、系统越来越庞大、功能越来越复杂、技术更新迭代不断,促生了对新一代高效框架和开发工具的需求。

       在这篇文章里我们要介绍  一个结合了可靠架构企业应用程序必备功能和快速应用程序开发工具的开源框架有助于大幅提研发团队的开发效率、提高交付质量

CUBA平台与其他框架有何不同?

      CUBA平台与其他大多数Java框架最大的区别是:它的抽象级别更高,开发人员可以只专注于解决业务问题它把稍高但是又有些偏“底层”的技术细节(如VaadinSpringEclipseLink也封装起来并自带丰富的应用功能和开发工具,因此开发人员可以最大限度地专注于业务实现 同时CUBA不限制对底层代码的访问这样可以保证框架可以适应具体项目的需求。

        CUBA平台能为开发企业应用程序带来巨大价值复杂的数据模型数十或数百个页面、各式各样的业务流程、系统的健壮性安全性等等。  

CUBA应用内部细节初探

架构

       CUBA应用程序具有标准的三层体系架构连接各层的纽带是元数据就是我们所知的数据模型。它使所有可视组件都具有数据感知能力。比如,表格可以知道自己展示实体的属性、标签知道自己在显示日期。类似地,元数据有助于可视组件通过ORM与数据层进行通信,ORM用来定义对象的关系图,决定是否需要加载或者更新数据。安全子系统、报生成器和平台的其他组件也有同样的机制

前端界面(Vaadin)

       CUBA-Platform使用Vaadin作为默认的前端界面框架,并提供声明式的界面开发模型,用户可以在可视化设计器或XML中定义布局CUBA框架内置70多种Vaadin可视组件选择,比如各类按钮表格组件、树组件、表单字段、 地图组件、动态图表透视表等等,涵盖企业应用界面需要的一切组件界面定义完成后,Java控制器中添加组件的初始化逻辑和事件处理逻辑。基于组件的数据感知功能用户可以非常快速地创建专业的企业应用页面。业务逻辑代码页面布局代码分离系统更易于维护。如果各式各样可视化组件还是不能满足用户需求CUBA也可以灵活的集成外部JavaScriptGWTVaadin组件。

图片1.png 

[WEB前端界面示例]

 

 

端界面 (Polymer)

       Google PolymerCUBA-Platform的另一个可选的前端界面技术,通过Restful APICUBA项目服务端进行通讯。Google Polymer客户端界面一般用于功能操作较少,但界面要求更灵活、可提供移动优先的响应式WEB界面。

图片2.png 

[Polymer界面示例]

 

过滤器

         CUBA用户界面一个重要功能:过滤器这个组件能够让用户自定义搜索条件,并且开发起来很简单:开发人员只需将放到一个显示实体列表的页面就万事大吉了。用户或管理员可以根据各自的需求定义各自的搜索条件。

       过滤器得益于CUBA元数据驱动的开发理念,过滤器能感知到自己绑定的实体,通过元数据,过滤器可准确地展示出表格可过滤的字段、限制关键字的值类型、提供备选值列表等。

图片3.png 

[添加过滤字段]

图片4.png 

[过滤器界面]

安全控制

      访问控制对于企业级应用来说至关重要,在CUBA项目中所有用户操作均由安全子系统控制

       CUBA支持实体级别、行级别、实体属性级别(列级别)的数据读写控制;功能界面功能也可以基于角色开放或拒绝;也可以对界面上的组件进行基于角色的权限控制。行级别的安全机制用来控制用户只对实体的某些数据记录(行)的访问 - 例如,部门的用户只能看到该部门用户创建的文档。

       所有权限设置都可以在运行时通过界面进行配置,所有更改都可以由系统管理员线上操作当然所有数据的更改历史都有记录,谁在何时更改了什么 -出现问题时溯源以及汇报很方便!

企业级应用必备功能

内置基础的WEB安全设施

         CUBA-Platform作为一个框架,整合了最佳安全实践,可自动对WEB应用程序中的大部分常见漏洞提供防护。比如跨站脚本(XSS)×××、跨站请求伪造×××(CSRF)、SQL注入×××等。

用户管理模块

       用户管理模块包含了用户管理、角色管理、访问组管理等界面,通过用户管理模块可在运行时对系统用户、角色、访问组进行增、删、改的维护;可对用户的权限进行管理。

管理工具

       CUBA-Platform内置了多个管理员实用工具,这些有助于系统管理员了解系统的运行情况、快速查找定位系统问题、自动执行重复性的管理任务等。

       日志查看功能

       通过日志查看功能,系统管理员不必登录服务器,直接登录系统来查看各种日志,比如服务器日志、实体日志、session日志等。

       实体(Entity)探查 

        CUBA-Platform可在运行时分析实体定义、动态生成实体数据浏览界面、数据编辑界面,管理员可通过实体探查功能查看、维护系统数据。

       性能统计

       通过性能统计功能,管理员可 全面了解系统运行的数据,比如系统运行时间、内存占用数据、CPU占用数据、数据库连接数据、客户端请求数据等。这些数据可为管理员优化系统配置、硬件配置、排查问题提供依据。

       定时任务

       通过定时任务,管理员可配置任意需要周期性或定时执行的任务,比如定时清理磁盘空间、定时发送系统状态通知等。

       数据恢复

       CUBA-Platform支持数据软删除,实体删除执行了删除操作后并不被物理删除,只是给数据添加了删除标记。如果发生了数据误删,管理可通过数据恢复功能恢复删除的数据。

       Session查看

       通过用户会话功能,管理员可查看所有在线的用户,并可对用户会话进行管理。比如发送消息给用户、注销用户登录等。

多语言和多时区支持

       CUBA-Platform提供了标准化多语言开发规范,可以使业务系统很方便地支持多国语言,这点对于开发国际性的业务系统很有帮助。

通用REST API

       通过CBUA-Platform可很容易地实现REST API方便外部系统与CUBA开发的业务系统进行集成,外部系统可以通过REST API调用基于CUBA的业务系统的中间件服务、访问领域实体数据。交互的数据格式支持JSONXML

管理

       报表模块可以帮助开发人员快速生成各种类型的统计报表,并支持以多种格式输出。

工作流模块

       CUBA PlatformBPM模块基于Activiti,提供流程设计、执行和管理业务流程的工具,支持BPMN 2.0标准。

全文检索

       CUBA-Platform的全文搜索(FTS)功能实体属性和上传的文件内容进行索引,提供非结构化搜索。

CUBA应用部署

       在程序部署软件运行环境方面,可选项很多CUBA应用程序有多种部署配置方案可以在单个服务器运行所有程序或者采用单独中间件(后台服务程序)加Web集群的方式

       平台开箱支持的数据库有:PostgreSQLOracleMicrosoft SQL ServerMySQLHSQL(通常用于原型设计),随着项目的发展用户也可以轻松地切换数据库。

      WEB应用方面, CUBA应用程序可以部署到任何Java EE Web 服务器(例如JettyTomcatGlassfishWebsphere)。当然,用户也可以把应用编成Docker镜像,也可以在流行的PaaS云中部署,比CloudFoundryOpenShiftJelastic

如何开发CUBA应用?

       使用CUBA 平台开发应用程序,你只需要懂得Java SEXMLJPQL – 你的应用程序代码会更统一易于维护。的开发团队更加灵活并不需要专门的Web开发人员或Java EE专家团队

图片5.png

       用户可以自己选择IDE开发业务逻辑,比如IntelliJ IDEAEclipseCUBA也提供CUBA应用的集成开环境:CUBA Studio – 一个辅助开发的可视化工具,CUBA有关的任务都可以通过它自动完成:

   · 配置项目基础信息可视化设计UI和数据模型

   · 带有多种布局选项的增删查改脚手架页面

   · 自动生成和运行数据库脚本

   · 监听处理器(handlers)和接口创建脚手架代码

         StudioIDE之间的所有改动都是同步的,用户可以完全自由地选择在哪里进行更改。为了进一步提高开发人员的效率Studio会自动热部署除数据模型之外的所有代码。因此,Studio大大避免了例行工作和编写样板代码的工作量而且还不限制用户对编码工具的选择

如果用户考虑将旧系统升级到流行的技术栈CUBA有解决方案Studio自带的迁移工具可以将旧数据库转换为符合CUBA平台的数据库,并根据数据模型自动生成页面,用户只需要添加自定义页面和迁移业务逻辑代码

收费吗?

       如标题所述,核心框架CUBA Framework是开源的,Apache 2.0许可, 源码都在GitHub上。所以对用户在CUBA上开发的软件没有许可限制。您可以免费使用IDEAEclipse基于CUBA Framework进行业务系统的开发。

       如果您想加快开发过程或者团队中有一些初级开发人员,那么您可以使用CUBA Studio来帮助提升开发效率。CUBA Studio提供免费和商业版本。免费版的CUBA Studio功能齐全,但限制了应用程序数据模型数量免费版创建项目和探索平台功能的理想选择在项目达到了免费版限制后,如果想进一步开发可以在Java IDE中继续开发,或者购买商业许可证。商业版支持更多高级附加组件:报图表地图全文搜索和工作流

 

结束

       CUBA-Platform是一个基础设施可靠、通用功能完善的开发框架,一篇文章不足以概括她的方方面面。希望本文可以让有一个初步的了解并且决定亲自试一试接下来您可以:根据在几分钟内运行您的第一个CUBA应用程序!

       您也可以访问我们的,通过讨论提交您的问题、想法

图片8.pngspacer.gif