软件行业企业管理信息系统(OurERP)是基于G4Studio平台开发且作为G4Studio产品线一部分,专门为中小软件企业量身定制开发的行业
ERP系统。OurERP将深入研究软件生产工艺及过程质量保障、IT项目管理理论,广泛邀请业界各层人士参与分析设计,从中小软件企业自身实际出发并结
合先进的软件过程和IT项目管理理念,理论联系实践,打造一套蕴涵了先进管理思想和最佳管理实践的适合中小软件企业自己用的开源ERP系统,以满足和规范
引导中小软件企业日常管理需求,解决IT项目管理难题,与G4Studio产品线部件一起让中小软件企业飞起来!
1.4.11.G4Stusio开发指南
《G4Studio开发指南》也就是本文档,作为G4Studio官方唯一指定的权威参考文档。
1.5.G4Studio技术架构体系
1.5.1.G4Studio平台技术架构总体结构图
本节将从G4Studio底层技术架构的静态视角带领大家一起走进G4Studio。如下图2为G4Studio平台技术架构总体结构图。
关于上图的一点说明(请结合图中数字标注阅读):
①、
ExtJS作为G4Studio应用富浏览器客户端的主要组成部分。虽然ExtJS稍显臃肿的体积和动态构造Dom和渲染使得其在部分浏览器上(比如
IE,尤其是IE6)上的表现饱受争议和诟病。但是辅以G4Studio平台提供的压缩和缓存技术以及一系列的优化手段,G4Studio富客户端不但能
在Intranet上完美表现,而且在复杂不可控的Internet环境下也一样能得到可接受范围内的性能表现。对于G4Studio客户端双兼容架构之
一的富桌面客户端通过HTTP协议和部署在远端的业务服务组件进行通信并以Java原生系列化技术对数据传输对象进行系列化操作,不但能得到HTTP无限
穿越网络防火墙的先天优势也能得到Java原生高性能系列化技术的支持。因此,G4Studio富桌面客户端一样能够在Intranet和
Internet环境下有着卓越表现。
②、G4Studio借助Java先天跨平台优势,使得基于G4Studio的应用可以方便的部署到Windows、Linux、HP-Unix、IBM-AIX操作系统上。
③、G4Studio目前支持且经过严格测试的服务器及版本为:Weblogic9.2(+)、Tomcat5.0(+)、Jetty6.0(+)、G4Server。
④、G4Studio目前支持的数据库中间件及版本为:Oracle、Mysql5.0(+)、H2。
⑤、G4Studio提供了稳定成熟的应用框架和丰富完善的技术组件库。在应用框架的组合上,我们参考设计模式但不拘泥于设计模式,以实用、快速开发为目标并结合平台开发插件,使得G4Studio二次开发人员能够非常快速的开发出行业应用功能模块来。丰富完善的技术组件库让你在开发过程中碰到任何技术问题都有现成可靠的解决办法,各种难题迎刃而解,彻底解放程序员,让他们更多时间和精力关注和解决业务域的问题,创造更大更可观的价值回报。
⑥、业务组件库是基于G4Studio应用框架和技术组件库开发的一些平台预置功能模块。其中包括企业组织机构能力模型参考实现、系统管理及权限模型参考实现、通用业务参考实现。
⑦、G4Studio平台对业务建模、流程建模、业务重组集成、设计开发、运行测试、应用部署整个生命周期都提供了不同程度的支持。
批注:上图中虚线框部分为在G4Studio蓝图中但当前版本未实现的部分。我们会在后续版本陆续推出。
1.5.2.G4Studio技术架构层次调用图
本节将从G4Studio层次调用和分层模型和调用的动态视角和大家一起走进G4Studio。如下图3为G4Studio平台技术架构分层调用图。
关于上图的一点说明(请结合图中数字标注阅读):
①、G4Studio平台UI表现层同时支持富浏览器客户端和富桌面客户端两种UI表现方案,且支持移动终端设备的数据接入和访问。(G4Studio平台目前版本没有提供移动平台开发框架,仅提供移动终端设备的数据访问交互接口)
②、
控制逻辑层主要由Web过滤器和Struts-Action组成。接收浏览器客户端请求,调用视图服务层、业务模型服务层、数据访问层来完成业务处理和数
据访问以及页面流程跳转,并将处理结果返回给浏览器客户端。特别强调:缺省情况下,控制逻辑层直接调用业务模型服务层完成业务逻辑处理;针对非事务类交
易,比如查询交易,我们也可以在控制逻辑层使用数据读取接口g4Reader直接和数据库交互进行数据的读取操作。
③、
视图服务层是SOA架构的扩展结构,解决与周边软件的互联互通。它将业务模型服务层的商业逻辑组件进行包装或重组后,以多种远程服务的形式发布,对外暴露
服务,提供给第三方系统或G4Studio平台的Win32桌面客户端调用。完成异构系统之间的无缝集成和数据交互。特别强调:试图服务层只提供给
G4Studio平台的Win32桌面客户端以及第三方系统调用。对于大部分行业系统而言,不建议在控制逻辑层调用视图服务层,而应该跳过视图服务层直接
调用业务模型服务层。
④、业务模型服务层完成对行业业务商业逻辑的封装。提供给控制逻辑层或视图服务层调用。
⑤、
数据访问层提供和数据库之间的数据访问和对数据进行持久化。在G4Studio平台中,我们为了简化DAO层的开发,并没有对数据访问层进行独立分层。在
G4studio平台中,数据访问层是一个逻辑层的概念,我们暴露了两个数据访问接口g4Reader和g4Dao。其中g4Reader数据访问接口直
接和控制逻辑层耦合,完成非事务类查询交易操作;g4Dao数据访问接口直接和业务模型层耦合,完成事务类交易的数据访问。
⑥、浏览器客户端通过HTTP请求访问控制逻辑层,完成数据采集、编码转换、安全认证等操作。
⑦、控制逻辑层可以访问视图服务层,但对于大部分的应用系统而言,我们强烈建议控制逻辑层跳过视图服务层,直接访问业务模型服务层。
⑧、控制逻辑层调用业务模型服务层完成业务逻辑处理。
⑨、控制逻辑层直接调用数据访问层的非事务类数据访问接口进行查询类交易处理。
⑩、视图服务层调用业务模型服务层对其进行包装或业务重组后发布为远程服务组件。
⑾、业务模型服务层调用数据访问层的事务类数据访问接口进行数据持久化处理。
⑿、数据访问层和数据库之间的交互。
1.5.3.G4Studio技术架构数据流图
本节将从G4Studio平台数据交互和流向的视角带领大家一起走进G4Studio。如下图4为G4Studio平台技术架构数据流向图。
关于上图的一点说明(请结合图中数字标注阅读):
①、
浏览器通过HTTP以Form提交和请求参数提交的方式首先经过平台的编码过滤器和安全认证器,然后将数据采集到控制逻辑器Action中,Action
将界面数据包装为Dto后调用Dao进行数据查询或调用业务服务组件BizService进行业务处理后将查询结果集或业务处理返回结果序列化为JSON
对象通过HttpSerletResponse返回给浏览器客户端。
②、
Action将界面采集的数据组装为DTO对象后调用试图服务ViewService。特别强调:一般情况下,我们不走这条线。只有在系统的业务服务组件
要同时支持各种异构客户端接入的时候,出于接口统一的因素,我们才需要考虑浏览器客户端是否要走这条线路。注意:并不是说有异构客户端接入时浏览器客户端
就必须走这条路,而是如果为了要和其它客户端保持统一的接入口时才需要在Action调用视图服务。因为调用视图服务和其它异构客户端保持一致接口是需要
付出性能代价的,具体情况得根据实际项目而定。
③、Action将界面采集的数据组装为DTO对象后调用业务服务组件BizService进行业务处理,并将处理结果以DTO对象返回给Action。
④、针对一些非事务类的查询操作,为了简化DAO编程,我们可以在Action中将界面采集的查询条件包装为DTO对象后直接调用非事务类DAO查询接口g4Reader,并将结果集以DTO、
JavaBean、ArrayList等类型的数据对象返回给Action。
⑤、业务服务组件BizService将相关业务数据组装为DTO对象或者JavaBean后调用事务类DAO访问接口g4Dao进行数据查询、数据持久化和存储过程调用操作。
⑦、数据访问接口将DTO对象、JavaBean交给DAO实现将其映射为相应的SQL语句向数据库发出请求,并将数据库返回的结果集映射为DTO、JavaBean、等数据类型对象返回给数据访问接口调用端。
⑧、
对于桌面客户端我们可以将其简单分为2类。一类是使用G4Studio平台提供的基于SWT/Jface图形库的富桌面客户端开发框架开发出来的桌面客户
端,对于这种客户端而言,我们使用HttpInvoker技术直接通过http协议访问视图服务ViewService,相互之间可之间通过DTO或者其
它任意可系列化的Java对象来进行参数传递和数据交互。另一类是使用其它开发工具比如Delphi、VB、VC等开发出的桌面客户端,对于这类桌面客户
端发出的请求可以通过WebService使用Soap协议调用视图服务组件,以系列化的XML资料格式进行数据交互。
⑨、对于移动终端设备,我们提供Webservice数据接入技术。
1.6.G4Studio第三方组件依赖关系
G4Studio平台取得的成绩,离不开大量的第三方开源组件的贡献。也正式由于这些开源组件才成就了Java阵营开源社区百花齐放,欣欣向荣的大好景象。在平台研发过程中,我们反复论证精选了一些成熟稳定的开源组件应用到G4Studio中来,如下图5所示:G4Studio第三方组件依赖关系。在此,我们也像这些开源组件的作者表示由衷的感谢和敬意。提示:如下所示部分组件为商业不友好组件或收费组件,建议大家使用时根据自己项目实际情况酌情删减或按照相应组件的开源协议灵活使用。