(本文为本人原创,转载请著名作者及本页网址,谢谢-阿P) 1、 定义 所谓“插件模型”,指应用程序由一些动态的独立模块构成,每个模块均具有一个或多个服务,并满足一定的插件协议,能够借助主程序实现主程序-插件;插件-插件之间的通讯。 应用该模型的系统,具有以下特点: 1) 所有业务功能均是“砖块”,更新及维护简便 2) 子系统的概念变得模糊,子系统是多个模块的组合 3) 有效避免功能的重复开发 4) 可以根据用户需求定制系统,真正的随需而变 5) 当功能插件达到一定规模时,应用系统的开发将变成二次开发 6) 实现化整为零的组织结构,每个模块由微小的团队负责,甚至一个人负责 7) 开发能力要求降低,类似于报表、查询等易变、简单的模块,维护人员即可完成
2、 体系结构组成
系统结构如下图:
图一 系统结构示意图
系统组成元素如下:
1) 应用程序 2) 应用程序配置文件 3) 插件协议 4) 插件 5) 共通组件、控件 6) 远程访问代理 7) 中间层 8) 底层数据库
3、 详细说明 1) 应用程序 应用程序是用户操作的平台,也是所有业务插件的容器,其本身不会有太多的功能,主要通过读取配置文件来配置整个应用程序;包含以下功能: ·主画面 ·界面配置管理 ·插件管理 2) 应用程序配置文件 包括界面配置和插件配置,采用加密过的XML文件保存配置 ·界面配置 ·插件配置 3) 插件协议(PluginSdk) 是整个插件模型的运行核心,主要包括用于插件的基类和用于通讯的控制类 ·插件基类(PluginBase) ·插件控制类(PluginControl) 4) 插件 基于插件协议,借助共通插件、控件及远程访问代理和业务层配合实现特定的业务 ·插件基类派生类 ·业务功能实现类 5) 共通组件、控件 是整个体系的运行基础,也是产品化的基础 ·权限控制套件 ·界面控件库 ·常量库 ·工具库 6) 远程访问代理 也许系统是基于Web服务的,也许系统是基于其它服务的,总之系统的业务实现很大部分放在远程,这个代理就可以让客户端很好的访问远程服务。 ·远程访问代理类 7) 中间层 实现客户端与数据库端的通讯,抛开繁杂的层次步骤,提供简单高效的通讯服务 ·服务外观层(Web Service) ·数据访问层(DataAccess) ·数据库代理(DBHelp)/中间件(MiddleWare) 8) 底层数据库 可以是Oracle,也可以是SqlServer(在实现中间件的前提下),在现有情况下,主要业务还由存储过程来实现。
|