《权限管理概要设计.doc》由会员分享,可在线阅读,更多相关《权限管理概要设计.doc(77页珍藏版)》请在taowenge.com淘文阁网|工程机械CAD图纸|机械工程制图|CAD装配图下载|SolidWorks_CaTia_CAD_UG_PROE_设计图分享下载上搜索。
1、Four short words sum up what has lifted most successful individuals above the crowd: a little bit more.-author-date权限管理概要设计密级:机密JM通用权限管理概要设计说明书 V1.0文件更改摘要:日期版本号修订说明修订人审核人批准人2007-10-81.0创建谢星星目录1.引言41.1 编写目的41.2 背景41.3 术语41.4 预期读者与阅读建议41.5 参考资料42.总体设计42.1 设计目标42.2 运行环境42.3 网络结构52.4 总体设计思路和处理流程52.5 模块结
2、构设计72.6 尚未解决的问题73.接口设计(暂略)73.1 用户接口(暂略)73.2 外部接口(暂略)73.3 内部接口(暂略)74.界面总体设计74.1 组权限管理84.1.1 包含用户84.1.2 所属角色84.1.3 组权限94.1.4 总权限94.1.5 组管理104.2 角色权限管理104.2.1 包含用户104.2.2 包含组114.2.3 角色权限114.2.4 管理角色124.3 用户权限管理124.3.1 所属角色124.3.2 所属组134.3.3 用户权限134.3.4 总权限144.3.5 用户管理154.3.6 组织管理154.4 操作日志管理154.4.1 查询操
3、作日志154.4.2 删除操作日志165.数据结构设计165.1 设计原则165.1.1 命名的规范165.1.2 数据的一致性和完整性165.2 数据库环境说明175.3 数据库命名规则175.4 逻辑结构175.5 物理存储175.6 数据备份和恢复176.系统出错处理设计176.1 出错信息176.2 补救措施187.系统安全设计187.1 数据传输安全性设计187.2 应用系统安全性设计187.3 数据存储安全性设计181. 引言1.1 编写目的本文档对通用权限管理系统的总体设计、接口设计、界面总体设计、数据结构设计、系统出错处理设计以及系统安全数据进行了说明。1.2 背景a、 软件系
4、统的名称:通用权限管理系统;b、 任务提出者、开发者:谢星星;c、 在J2EE的web系统中需要使用权限管理的系统。1.3 术语本系统:通用权限管理系统;SSH:英文全称是Secure Shell。1.4 预期读者与阅读建议预期读者阅读重点开发人员总体设计、接口设计、数据结构设计、界面总体设计、系统出错处理设计设计人员总体设计、接口设计、数据结构设计、系统安全设计1.5 参考资料通用权限管理系统需求规格说明书通用权限管理系统数据库设计说明书2. 总体设计2.1 设计目标权限系统一直以来是我们应用系统不可缺少的一个部分,若每个应用系统都重新对系统的权限进行设计,以满足不同系统用户的需求,将会浪费
5、我们不少宝贵时间,所以花时间来设计一个相对通用的权限系统是很有意义的。本系统的设计目标是对应用系统的所有资源进行权限控制,比如应用系统的功能菜单、各个界面的按钮控件等进行权限的操控。2.2 运行环境操作系统:Windows系统操作系统和Linux系列操作系统。2.3 网络结构通用权限管理系统可采用Java Swing实现,可以在桌面应用和Web应用系统中进行调用。如果需要要适应所有开发语言,可以将其API发布到WEB Service上。暂时用Java Swing实现。2.4 总体设计思路和处理流程在说明总体设计思路前,我们先说明本系统的相关概念:1. 权限资源系统的所有权限信息。权限具有上下级
6、关系,是一个树状的结构。下面来看一个例子系统管理 用户管理 查看用户新增用户修改用户删除用户对于上面的每个权限,又存在两种情况,一个是只是可访问,另一种是可授权,例如对于“查看用户”这个权限,如果用户只被授予“可访问”,那么他就不能将他所具有的这个权限分配给其他人。2. 用户应用系统的具体操作者,用户可以自己拥有权限信息,可以归属于0n个角色,可属于0n个组。他的权限集是自身具有的权限、所属的各角色具有的权限、所属的各组具有的权限的合集。它与权限、角色、组之间的关系都是n对n的关系。3. 角色为了对许多拥有相似权限的用户进行分类管理,定义了角色的概念,例如系统管理员、管理员、用户、访客等角色。
7、角色具有上下级关系,可以形成树状视图,父级角色的权限是自身及它的所有子角色的权限的综合。父级角色的用户、父级角色的组同理可推。4. 组为了更好地管理用户,对用户进行分组归类,简称为用户分组。组也具有上下级关系,可以形成树状视图。在实际情况中,我们知道,组也可以具有自己的角色信息、权限信息。这让我想到我们的QQ用户群,一个群可以有多个用户,一个用户也可以加入多个群。每个群具有自己的权限信息。例如查看群共享。QQ群也可以具有自己的角色信息,例如普通群、高级群等。针对如上提出的四种对象,我们可以整理得出它们之间的关系图,如下所示:总体设计思路是将系统分为组权限管理、角色权限管理、用户权限管理、组织管
8、理和操作日志管理五部分。其中组权限管理包括包含用户、所属角色、组权限资源和组总权限资源四部分,某个组的权限信息可用公式表示:组权限 = 所属角色的权限合集 + 组自身的权限。角色权限管理包括包含用户、包含组和角色权限三部分,某个角色的权限的计算公式为:角色权限 = 角色自身权限。用户权限管理包括所属角色、所属组、用户权限、用户总权限资源和组织管理五部分。某个用户总的权限信息存在如下计算公式:用户权限 = 所属角色权限合集 + 所属组权限合集 + 用户自身权限。组织管理即对用户所属的组织进行管理,组织以树形结构展示,组织管理具有组织的增、删、改、查功能。操作日志管理用于管理本系统的操作日志。注意
9、:因为组和角色都具有上下级关系,所以下级的组或角色的权限只能在自己的直属上级的权限中选择,下级的组或者角色的总的权限都不能大于直属上级的总权限。2.5 模块结构设计本系统的具有的功能模块结构如下图所示:2.6 尚未解决的问题无。3. 接口设计(暂略)3.1 用户接口(暂略)3.2 外部接口(暂略)3.3 内部接口(暂略)4. 界面总体设计本节将阐述用户界面的实现,在此之前对页面元素做如下约定:序号页面元素约定1按钮未选中时:按钮名称选中时:按钮名称2单选框 选项3复选框 选项4下拉框 选项, 5文本框 |_|6TextArea |7页签未选中时:选项名称 选中时:选项名称8未选中链接链接文字9
10、选中链接链接文字10说明信息说明信息4.1 组权限管理4.1.1 包含用户组信息 组1 组11 组12 组 组2 组21 组22 组所选择组:组1 包含用户 所属角色 组权限 总权限修改用户名 姓名 手机号 最近登录时间 登录次数阿蜜果 谢星星 13666666666 2007-10-8 66sterning xxx 13555555555 2007-10-8 10 当用户选择“修改”按钮时,弹出用户列表,操作人可以通过勾选或取消勾选来修改该组所包含的用户。4.1.2 所属角色组信息 组1 组11 组12 组 组2 组21 组22 组所选择组:组1 包含用户 所属角色 组权限 总权限修改角色I
11、D 角色名称 角色描述1 访客 - 2 初级用户 - 当用户选择“修改”按钮时,弹出角色树形结构,操作人可以通过勾选或取消勾选来修改该组所属的角色。4.1.3 组权限组信息 组1 组11 组12 组 组2 组21 组22 组所选择组:组1 包含用户 所属角色 组权限 总权限保存 取消4.1.4 总权限组信息 组1 组11 组12 组 组2 组21 组22 组所选择组:组1 包含用户 所属角色 组权限 总权限保存 取消通过对已具有的权限取消勾选,或为某权限添加勾选,来修改组的权限信息,点击“保存”按钮保存修改信息。4.1.5 组管理在下图中,选中组1的时候,右键点击可弹出组的操作列表,包括添加、
12、删除和修改按钮,从而完成在该组下添加子组,删除该组以及修改该组的功能。组信息 组1 组11 组12 组 组2 组21 组22 组所选择组:组1 包含用户 所属角色 组权限 总权限修改用户名 姓名 手机号 最近登录时间 登录次数阿蜜果 谢星星 13666666666 2007-10-8 66sterning xxx 13555555555 2007-10-8 10 4.2 角色权限管理4.2.1 包含用户角色信息 角色1 角色11 角色12 角色 角色2 角色21 角色22 角色所选择角色:角色1 包含用户 包含组 角色权限修改用户名 姓名 手机号 最近登录时间 登录次数阿蜜果 谢星星 1366
13、6666666 2007-10-8 66sterning xxx 13555555555 2007-10-8 10 当用户选择“修改”按钮时,弹出用户列表,操作人可以通过勾选或取消勾选来修改该角色所包含的用户。4.2.2 包含组角色信息 角色1 角色11 角色12 角色 角色2 角色21 角色22 角色所选择角色:角色1 包含用户 包含组 角色权限修改组ID 组名称 组描述1 xxx1 -2 xxx2 - 当用户选择“修改”按钮时,弹出用户列表,操作人可以通过勾选或取消勾选来修改该角色所包含的组。4.2.3 角色权限角色信息 角色1 角色11 角色12 角色 角色2 角色21 角色22 角色所
14、选择角色:角色1 包含用户 包含组 角色权限 保存 取消通过对已具有的权限取消勾选,或为某权限添加勾选,来修改角色的权限信息,点击“保存”按钮保存修改信息。4.2.4 管理角色在下图中,选中组1的时候,右键点击可弹出组的操作列表,包括添加、删除和修改按钮,从而完成在该组下添加子组,删除该组以及修改该组的功能。角色信息 角色1 角色11 角色12 角色 角色2 角色21 角色22 角色所选择角色:角色1 包含用户 包含组 角色权限修改用户名 姓名 手机号 最近登录时间 登录次数阿蜜果 谢星星 13666666666 2007-10-8 66sterning xxx 13555555555 200
15、7-10-8 10 4.3 用户权限管理4.3.1 所属角色用户权限信息xx公司 广州分公司 阿蜜果 肖xx yy 北京分公司 zz1 zz2 zz3所选择用户:阿蜜果 所属角色 所属组 用户权限 总权限修改角色ID 角色名称 角色描述1 访客 - 2 初级用户 -当用户选择“修改”按钮时,弹出角色树形结构,操作人可以通过勾选或取消勾选来修改该用户所属的角色。4.3.2 所属组用户信息xx公司 广州分公司 阿蜜果 肖xx yy 北京分公司 zz1 zz2 zz3所选择用户:阿蜜果 所属角色 所属组 用户权限 总权限修改组ID 组名称 组描述1 组1 - 2 组2 -当用户选择“修改”按钮时,弹
16、出组的树形结构,操作人可以通过勾选或取消勾选来修改该用户所属的组。4.3.3 用户权限用户信息xx公司 广州分公司 阿蜜果 肖xx yy 北京分公司 zz1 zz2 zz3所选择用户:阿蜜果 所属角色 所属组 用户权限 总权限 保存 取消通过对已具有的权限取消勾选,或为某权限添加勾选,来修改用户的权限信息,点击“保存”按钮保存修改信息。4.3.4 总权限用户信息xx公司 广州分公司 阿蜜果 肖xx yy 北京分公司 zz1 zz2 zz3所选择用户:阿蜜果 所属角色 所属组 用户权限 总权限 保存 取消通过对已具有的权限取消勾选,或为某权限添加勾选,来修改用户的权限信息,点击“保存”按钮保存修
17、改信息。4.3.5 用户管理当选择了某用户时,点击右键,弹出菜单列表:修改、删除、取消,点击修改和删除按钮可以实现用户的删除和修改功能。选择某个组织,例如下表中的“广州分公司”,弹出菜单列表:添加子组织、删除组织、修改组织、添加用户、取消,点击添加用户按钮可以实现用户的添加功能。用户权限信息xx公司 广州分公司 阿蜜果 肖xx yy 北京分公司 zz1 zz2 zz3所选择用户:阿蜜果 所属角色 所属组 用户权限 总权限修改角色ID 角色名称 角色描述1 访客 - 2 初级用户 -4.3.6 组织管理选择某个组织,例如下表中的“广州分公司”,弹出菜单列表:添加子组织、删除组织、修改组织、添加用
18、户、取消,点击添加子组织、删除组织、修改组织按钮可以实现组织的添加、删除和修改功能。用户权限信息xx公司 广州分公司 阿蜜果 肖xx yy 北京分公司 zz1 zz2 zz3所选择用户:阿蜜果 所属角色 所属组 用户权限 总权限修改角色ID 角色名称 角色描述1 访客 - 2 初级用户 -4.4 操作日志管理4.4.1 查询操作日志操作名称:|_| 操作人:|_| 操作时间从 |_| 到 |_| 查询 重置 删除编号 操作名称 操作内容 操作人 操作时间1 xx1 - Amigo 2007-10-82 xx2 - xxyy 2007-10-8输入上图表单中的查询信息后,点击“查询”按钮,可查询
19、出符合条件的信息。4.4.2 删除操作日志操作名称:|_| 操作人:|_| 操作时间从 |_| 到 |_| 查询 重置 删除编号 操作名称 操作内容 操作人 操作时间1 xx1 - Amigo 2007-10-82 xx2 - xxyy 2007-10-8输入上图表单中的查询信息后,点击“查询”按钮,可查询出符合条件的信息。而后点击“删除”按钮,可删除符合查询条件的操作日志。5. 数据结构设计数据库设计的模型请参见通用权限管理系统_数据库模型.pdm。表的说明请参见通用权限管理系统数据库设计说明书。5.1 设计原则5.1.1 命名的规范数据库中表、主键、外键、索引的命名都以统一的规则,采用大小
20、写敏感的形式,各种对象命名长度不要超过30个字符,这样便于应用系统适应不同的数据库平台。5.1.2 数据的一致性和完整性为了保证数据库的一致性和完整性,往往通过表间关联的方式来尽可能的降低数据的冗余。表间关联是一种强制性措施,建立后,对父表(Parent Table)和子表(Child Table)的插入、更新、删除操作均要占用系统的开销。如果数据冗余低,数据的完整性容易得到保证,但增加了表间连接查询的操作,为了提高系统的响应时间,合理的数据冗余也是必要的。使用规则(Rule)和约束(Check)来防止系统操作人员误输入造成数据的错误是设计人员的另一种常用手段,但是,不必要的规则和约束也会占用
21、系统的不必要开销,需要注意的是,约束对数据的有效性验证要比规则快。所有这些,需要在设计阶段应根据系统操作的类型、频度加以均衡考虑。5.2 数据库环境说明数据库:MySql5.0设计库建模工具:PowerDesigner12.05.3 数据库命名规则表名以T开头,外键以FK开头,索引以INDEX开头。5.4 逻辑结构pdm文件的名称为:通用权限管理系统_数据库模型。5.5 物理存储通过数据库建模工具PowerDesigner12可以将pdm导出为文本文件,将数据库脚本放入文本文件中保存。5.6 数据备份和恢复数据库需定期备份(每天备份一次),备份文件格式为backup_yyyyMMdd,数据库被
22、破坏时,利用最新的备份文件进行恢复。6. 系统出错处理设计6.1 出错信息错误分类子项及其编码错误名称错误代码备注数据库错误连接连接超时100001001连接断开100001002数据库本身错误代码数据库本身错误代码100002+数据库错误代码TCP连接错误连接连接超时101001001连接断开101001002其它TCP连接错误(socket自身错误代码)101002+ socket错误代码配置信息错误未配置输入参数102001未配置输出参数102002组管理部分自定义错误103001103999角色管理部分自定义错误104001104999用户管理部分自定义错误105001105999操作
23、日志管理1060011069996.2 补救措施为了当某些故障发生时,对系统进行及时的补救,提供如下补救措施: a后备技术 定期对数据库信息进行备份(每天一次),当数据库因某种原因被破坏时,以最新的数据库脚本进行恢复;。7. 系统安全设计7.1 数据传输安全性设计SSH可以通过将联机的封包加密的技术进行资料的传递; 使用SSH可以把传输的所有数据进行加密,即使有人截获到数据也无法得到有用的信息。同时数据经过压缩,大大地加快了传输的速度。通过SSH的使用,可以确保资料传输比较安全并且传输效率较高。7.2 应用系统安全性设计操作人的操作信息需要提供操作记录。对系统的异常信息需进行记录,已备以后查看。只有授权用户才能登录系统,对于某个操作,需要具有相应权限才能进行操作。7.3 数据存储安全性设计对于用户的密码等敏感信息采用MD5进行加密。-