在前面设计了读取系统配置信息的config模块,与DBMS交互的DBHelper模块,写日志的Logger模块,MVC模块,这些基本都是独立存在的积木块,我们需要将它们有效的结合在一起,构建出一个房屋框架来,然后在针对具体的业务领域时,我们就可以仅关注需要关注的地方。
这个信息系统的运行框架需要帮我们处理哪些事情?
1.需要一个运行入口(类似application.run的设计),
1.1. 初始化DBHelper实例(使用数据库相关的配置信息)
1.2. 初始化Logger实例(使用日志相关的配置信息)
1.3. 调用Login模块实现系统登录,获取一个Session(根据配置信息来确定login模块的相关信息,例如
- 从系统配置文件获取登录模块的信息
- 不使用登录界面<系统自动产生一个默认账号,拥有系统所有权限>,
- 是否自动登录
- 是否已记住上次登录用户名
- 等等
1.4. 获取系统的mainController,完成显示主界面,设置用户权限,配置用户工作区,获取用户工作消息/工作任务等内容,具体功能由主程序的mainController实例提供实现。这个运行框架提供一个mainController属性,然后提供一个run方法实现主程序的运行。框架主要代码如下:
TEFFramework = class
private
FMainControllerName: string;
public
procedure run;
property MainControllerName: string read FMainControllerName write FMainControllerName;
end;
implemention
{ TEFFramework }
procedure TEFFramework.run;
var
mainController: TController;
begin
if Login then
begin
mainController := TControllerFactory.findController(FMainControllerName);
mainController.showView;
application.run;
end
else
begin
application.terminate;
end;
end;
至于mainController及MainView的实现就不在TEFFramework的范围之内,这个可以放到具体的系统Project里实现。
这样,整个系统的运行框架搭建完成。
我们就可以使用这个框架来进行具体的系统设计了。
后续我会展示采用efFramework来实现一个APS生产排程系统。