继续,这是第五章了。我发现了,写文章比写程序还要有难度。另外,大家期待的高人——吉日嘎拉,已经露头了,他在第四章里面留言了,而且留了很多,回复的比较晚,可能有些Tx没有看到,如果您感兴趣可以去看看,如果不感兴趣就算了。
通用权限想要写的文章目录:(这是第五章)
1、 简介、数据库的总体结构
2、 介绍人员表组
3、 介绍组织结构表组
4、 介绍角色表组
5、 介绍“项目自我描述表组”
6、 权限到节点
7、 权限到按钮
8、 权限到列表(表单、查询)
9、 权限的验证
10、 资源方面的权限
11、 角色管理的程序(给客户用的)
12、 权限下放
13、 个性化设置
项目描述表组
这里的表比较多,主要分为两个部分,一个是“字典信息”,这里就不介绍了,感兴趣的话,请下载数据库说明文档;另一个就是装载配置信息的表。
项目描述,顾名思义就是想要用数据(记录)的形式来描述一个项目,当然不能所有的事情都能用数据的形式描述出来,只有和数据相关的地方才行。最初的目的是给我的几个自定义控件赋值用的,比如表格控件、表单控件、查询控件等,他们都需要很多的信息给他们的属性赋值,如果直接在代码里面写的话,那还不如直接拖拽控件简单呢,所以我就把需要的属性都放在了“表”里面。一开始并没有想到权限,后来才发现,只要修改一下SQL语句,就可以达到“权限”的目的,包括资源权限。同理,也可以达到“个性化设置”的效果。所以我感觉权限、个性化设置只是自然架构的一个副产品。当然你也可以说,通用权限和我的自定义控件绑定的太紧了,这个也没有办法,总之,先实现了需求再说,然后再想办法解决侵入性的问题。
为了便于大家的理解,在说明这些表的时候举一个举一个具体的例子吧。SQL Server 2000里面有一个 sysobjects 表,表里面有一个xtype字段,这个字段是说明类型的,比如xtype=’U ’,表示用户表,xtype=’V ’,表示视图。在网上查了一下,发现这个xtype字段至少有16种值,我做了一个表“Manage_Base_TableType”来记录这个信息。所以我这里就以这个表为例,说一下项目描述表组里的几个表的作用。
【Manage_Base_TableType的字段和数据】

项目描述表的说明
1、Manage_Function,功能节点表。这里记录了一个项目的所有的功能节点。通过这个表就可以看到这个项目可以做什么。很有项目描述的味道吧。
【字段】
字段名 | 中文名 | 字段类型 | 大小 | 默认值 | 是否空 | 说明 |
FunctionID | 节点ID | int | 4 | 1 | 主键 | |
ParentID | 父节点ID | 员工姓名 | ||||
ParentIDPath | 父节点ID的路径 | nvarchar | 30 | _ | ||
NoteTitle | 节点名称 | 100 | ||||
PowerMark | 权限标识 | 50 | 一般情况下等于FunctionID | |||
NoteLevel | 级数 | 第几级节点 | ||||
IsShowNote | 节点是否显示 | bit | 功能节点里面是否显示 | |||
IsShowPower | 角色是否显示 | 角色选择是否显示 | ||||
Sort | 排序 | |||||
WebURL | 网址 | 打开网页的网址 | ||||
Target | 目标 | 10 |
【示例】
这个表是权限到节点的关键表。下一章会详细说明,其实大家应该也知道了。
2、Manage_Table,记录数据库里的表的信息。他主要是区分一个字段是属于哪个表的。
TableID | 表 | |||||
TableName | 表名 | 60 | ||||
IDColumn | 主键名 | |||||
Type | 类型 | char | 2 | |||
Content | 表说明 | |||||
ExcelTableName | 工作表名称 | 用于修改Excel里面的信息 |
3、Manage_Columns,记录数据库里的表的字段的信息。在原有的基础上(字段名、字段类型、大小等),又增加了一些UI需要的信息,比如控件类型、验证方式等,就是说这个字段在表单里面表现为什么控件,这些是表单控件需要的信息。
ColumnID | 字段标识 | |||||
表ID | 外键 | |||||
ColSysName | 字段名称 | 数据库里的名称 | ||||
ColName | 对外名称 | 显示给用户看的名称 | ||||
ColType | 字段类型 | 20 | ||||
ColSize | 字段大小 | |||||
ControlKindID | 控件类型 | |||||
CheckKindID | 验证类型 | |||||
CheckUserDefined | 自定义验证 | 自行定义验证的方式,通过正则表达式实现。 | ||||
ControlInfo | 控件描述 | 500 | 描述控件 | |||
ControlID | 控件ID | 在页面里的控件ID |
4、Manage_Function_Info,这里记录了分页控件需要的属性,还有节点的添加、修改、删除时需要的表。
FunctionTitle | 列表标题 | |||||
TableNameList | 列表用的表名 | |||||
TableNameExcel | 导出Excel用的表名 | |||||
ForeignColumn | 外键名 | 如果是从表的话,可以填写外键表,用于显示数据时候的过滤条件 | ||||
SQLKindID | 分页算法 | |||||
PKColumn | ||||||
ShowColumns | 显示的字段 | * | ||||
OrderColumns | 排序字段 | |||||
PageSize | 一页记录数 | |||||
QueryAlways | 固定的查询条件 | 300 | ||||
Query | 第一次的查询条件 | |||||
NaviCount | 页号数量 | |||||
TableNameAdd | 添加数据用表 | |||||
TableNameUpdate | 修改数据用表 | |||||
TableNameView | 查看数据用表 | |||||
TableNameDel | 删除数据用表 |
5、Manage_FunFindCol,记录一个节点里面的查询控件需要的字段,又增加了查询类型的字段。
FindColID | 序号 | |||||
外键,关联节点 | ||||||
字段ID | 外键,关联字段 | |||||
同一节点下的排序 | ||||||
FindKindID | 查询方式 | 外键,查询方式 | ||||
DefaultValue | 默认值 | 第一次显示查询的时候的字段的默认查询关键字 | ||||
clearTDStart | 去掉开头的TD | 合并到上一个TD,设置空格 | ||||
clearTDEnd | 去掉结尾的TD | 接收下一个TD | ||||
TDColspan | TD数 | 一个字段占用多少TD |
6、Manage_FunFormCol,记录一个节点里面的表单控件需要的字段,增加了提示信息、控件状态等字段。可以绘制表单
FormColID | ||||||
ColHelp | 提示信息 | 出现在控件旁的提示信息,比如“用户名必须4-20个字符” | ||||
HelpStation | 提示信息的位置 | 1:不显示;2:左面;3:右面 | ||||
控件的默认值 | ||||||
ControlState | 控件状态 | 1:正常;2:只读;3:不可用 | ||||
IsShow | 是否显示 | 1:显示;0:不显示 | ||||
ClearTDStart | ||||||
ClearTDEnd | ||||||
7、Manage_FunListCol,记录一个节点的数据列表需要的字段。可以用这个信息绘制表格的表头。
ListColID | ||||||
ColWidth | 列宽度 | TD的宽度 | ||||
ColAlign | 列对齐方式 | left | TD的对齐方式 | |||
Format | 格式化 | 对信息进行格式化 | ||||
MaxLength | 最大字符数 | TD里面最多显示多少字符 |
8、Manage_ButtonBar,记录了一个节点有哪些功能按钮,比如添加、修改、删除、查询等。可以添加任意功能的按钮。可以绘制列表页面里的按钮。
ButtonID | ||||||
BtnTitle | 按钮标题 | 按钮上面显示的文字 | ||||
BtnID | 按钮ID | 按钮的ID | ||||
BtnTypeID | 按钮类型 | |||||
URL | 打开的网址 | 240 | 单击按钮后打开的网页 | |||
WebWidth | 打开窗口宽度 | |||||
WebHeight | 打开窗口高度 | |||||
IsNeedSelect | 是否需要选中数据 | 0:不需要;1:需要 | ||||