《易道客》源码剖析之二:模块的定义和使用
?
一、简介
此处的模块,指的是逻辑模块,一个物理模块(参见:模块的目录结构分析)可以包含多个逻辑模块。可以将某一功能定义成一个逻辑模块,一个逻辑模块可以被一个或多个菜单引用。
?
二、模块定义的相关实现类。
1、相关类:
(1)/common/module/Module.java? 模块类:定义一个模块,如:我的客户模块、联系人模块等。
(2)/common/module/Operation.java???? 操作类:定义一个模块包含的操作,如增加、修改等。
(3)/common/module/ModuleGroup.java????? 模块分组类:用于将模块分类管理。
(4)/common/module/ModuleFactory.java??? 模块工厂接口,定义一个模块时,需要实现该接口。
(5)/common/module/ModuleFere.java? 模块伴侣类:用于模块的注册和管理。
(6)/kh/main/jk/module/ModuleFactory_myClient.java???? “我的客户”模块定义,实现了ModuleFactory接口,用于产生“我的客户”模块。
?
2、前五个类定义在公共区域内,是整个系统功能模块化实现的类。第六个类是我的客户模块定义的一个例子,当我们开发一个新的功能模块时,就可以像ModuleFactory_myClient.java一样,定义一个模块。之后还需要在ModuleFere内将该模块注册发布,这样该模块就可以被各个菜单所引用。
?
3、前五个类只是普通的java类,而非bo对象。也就是说,一个模块的具体定义,是写死的程序代码中的(如:我的客户模块的定义,在ModuleFactory_myClient.java中),而不是存放在数据库中。之所以这么做,是考虑到模块的高内聚。如果存在数据库内,模块的本身代码和模块的定义就会分开,前者是在某个文件夹下面(/kh/main/),后面在数据库中,这样如果将某个模块从一个系统copy至别个系统中使用时,还在重新在另一个数据库内定义该模块,很不方便。(之前的系统框架曾是将Module、Operation、ModuleGroup对象存放在DB中,后面感觉不好,改成现在这样子。)
?
4、一个新模块的定义和注册方式。当编写一个新的功能模块时,需要在模块内的jk\module\文件夹下面,建立一个新的模块定义类,如ModuleFactory_myClient.java,具体可参见该类的代码。然后注册时,先确认该模块放在哪个模块分组中,然后在ModuleFere.java类中,先找到该模块分组处,添加如下几行代码。?
?
三、重要代码分析?
1、Module.java
??
?
?
?verNum,verSm分别用来说明该模块支持多少个版本,以及不同版本的差异。一个模块可以多个版本,菜单在引用模块时,需要说明以哪个版本号来使用该模块。不同的版本,在使用时,功能会有所差异。系统中各种类型数据(如:客户类别、客户所属区域等)的管理,用的就是一个模块不同的版本号来处理的。UserInfoLogin的nowSelectMenuModuleVer属性,始终记录着当前菜单以哪个版本号来使用当前模块,具体模块间的差异,需要编程实现。除非特殊需要,否则一般模块尽量只用一个版本号,降低程序复杂度,简单的永远是最好的。
2、Operation.java
?(1)在一个模块内,如增加、修改、删除分别代表三个不同的操作。
(2)classMethod将用于更细粒度的访问控制,在访问每一个action的方法时,都将判断是否有该方法的访问权限,具体可参见权限管理中的说明。
(3)type用于唯一标识一个模块内的某个操作(可以理解为功能按钮),同一模块能,不能出现重复的操作类型。操作类型的定义需要和action中按钮的定义的类型保持一致。此属性也是权限控制时使用,用于控制能否看到某个按钮(如:增加、修改、删除等)。type建议设置值:
?????? ????? ?01 增加 add
????????????? ?02 修改 update
????????????? ?03 删除 delete
????????????? ?04 详述 view
????????????? ?05 列表 list
?????????????????????????????????????????
????????????? ?11 增加_1 add_1
????????????? ?12 修改_1 update_1
????????????? ?13 删除_1 delete_1
????????????? ?14 详述_1 view_1
????????????? ?15 列表_1 list_1
????????????? ??????????????????????????
????????????? ?80 其他 other
????????????? ?81 其他_1 other_1
????????????? ?82 其他_2 other_2
????????????? ?83 其他_3 other_3
?
?3、ModuleFactory_myClient.java
?4、ModuleFere.java中的定义如下:
??groupId是整个客户管理区域(分组)的编号,所有区域编号不能重复,num是我的客户模块在分组内的编号,一个分组内,num不允许出现重复的值。ModuleFere是模块的注册地方,一个模块编写完成并在此处注册之后,就可以被菜单使用了。
?
四、模块的使用
1、启动tomcat,在浏览器中打开系统登陆界面,输入用户名devAdmin(注:开发管理员),密码是devAdmin+当前日期,如devAdmin20121226,进入后找到:系统配置—基础配置—菜单管理
2、先创建一个菜单,再修改其引用的模块信息。如下图:
?
3、用admin进入系统,给用户分配相应的权限即可。
?
?
?返回《易道客》主页
?