asp.net 一个简易权限的小例子设计
2007-05-12 11:13
429 查看
近日在阅读一本asp.net的书时(国人写的),其中提到了一个简易权限的小例子,感觉说的还是比较清楚,有点代表性,
故在此简单介绍下其实现原理
其核心是建立起用户、角色,功能,模块功能四者的关系。数据库设计如下
1 用户角色表
User表
字段:userid 自递增字段
username
password
RoleTable表(角色表)
字段
Roleid 自递增字段
RoleName
用户角色表 UserRole
字段
UserRoleid(自递增字段)
userid
roleid
用户表和角色表通过用户角色表进行关联,用户和角色之间的关系是多对多
2 角色权限表RoleRight
字段
RoleRightId 自递增字段
RoleId
ModuleFunctionId
这里解析一下,比如用户tom,具有管理员的角色(假设在roletable表中,存在如下一条记录
Roleid RoleName
2 admin
那么在RoleRight表中,存在如下形式的记录
RoleRightId RoleId ModuleFunctionId
1 2 10
2 2 11
即说明,roleid=2的管理员角色,具有moduleidfunctionid=10和11的权限
接着往下看
3 Module表(模块表)
字段
moduleid modulename url
1 学生档案 xxxxx
2 教师档案 xxxxxxx
4 ModuleFunction表(模块-功能表)
字段
modulefunctionid moduleid functionid
.....................
10 1 1
11 1 2
5 function表(功能表)
字段
functionid functioname
1 add
2 update
3 delete
4 search
可以看到,刚才管理员角色拥有的10,11两个权限,可以在modulefunction表中找到,即在moduleid=1(学生档案)这个模块中拥有两类
可以执行的功能,是什么功能呢?查看functionid可以知道,有add和update的功能了
这样的好处是,“模块”,“功能”,“组”,“人”可以任意添加,彼此不受影响。既可以直接为每个用户直接赋予权限,也可以为一类用户归到角色,再在角色里统一给权限。
但实际上,一般没多大必要设立function表去放这些权限,来来去去都是CRUD这些
故在此简单介绍下其实现原理
其核心是建立起用户、角色,功能,模块功能四者的关系。数据库设计如下
1 用户角色表
User表
字段:userid 自递增字段
username
password
RoleTable表(角色表)
字段
Roleid 自递增字段
RoleName
用户角色表 UserRole
字段
UserRoleid(自递增字段)
userid
roleid
用户表和角色表通过用户角色表进行关联,用户和角色之间的关系是多对多
2 角色权限表RoleRight
字段
RoleRightId 自递增字段
RoleId
ModuleFunctionId
这里解析一下,比如用户tom,具有管理员的角色(假设在roletable表中,存在如下一条记录
Roleid RoleName
2 admin
那么在RoleRight表中,存在如下形式的记录
RoleRightId RoleId ModuleFunctionId
1 2 10
2 2 11
即说明,roleid=2的管理员角色,具有moduleidfunctionid=10和11的权限
接着往下看
3 Module表(模块表)
字段
moduleid modulename url
1 学生档案 xxxxx
2 教师档案 xxxxxxx
4 ModuleFunction表(模块-功能表)
字段
modulefunctionid moduleid functionid
.....................
10 1 1
11 1 2
5 function表(功能表)
字段
functionid functioname
1 add
2 update
3 delete
4 search
可以看到,刚才管理员角色拥有的10,11两个权限,可以在modulefunction表中找到,即在moduleid=1(学生档案)这个模块中拥有两类
可以执行的功能,是什么功能呢?查看functionid可以知道,有add和update的功能了
这样的好处是,“模块”,“功能”,“组”,“人”可以任意添加,彼此不受影响。既可以直接为每个用户直接赋予权限,也可以为一类用户归到角色,再在角色里统一给权限。
但实际上,一般没多大必要设立function表去放这些权限,来来去去都是CRUD这些
相关文章推荐
- asp.net 一个简易权限的小例子设计
- asp.net 一个简易权限的小例子设计
- 有简易通用权限管理后台的快速C# ASP.NET开发的例子应用程序卖给了曾长期开发JAVA银行程序的大哥
- ASP.NET Zero--15.一个例子(8)商品分类管理-权限控制
- 有简易通用权限管理后台的快速C# ASP.NET开发的例子应用程序卖给了曾长期开发JAVA银行程序的大哥
- 有简易通用权限管理后台的快速C# ASP.NET开发的例子应用程序卖给了曾长期开发JAVA银行程序的大哥
- 有简易通用权限管理后台的快速C# ASP.NET开发的例子应用程序卖给了曾长期开发JAVA银行程序的大哥
- 有简易通用权限管理后台的快速C# ASP.NET开发的例子应用程序卖给了曾长期开发JAVA银行程序的大哥
- 有简易通用权限管理后台的快速C# ASP.NET开发的例子应用程序卖给了曾长期开发JAVA银行程序的大哥
- C# ASP.NET 最常用的通用权限的3个方法例子展示(每个功能一行代码实现)
- asp.net MVC 权限设计
- ASP.NET系统用户权限设计与实现
- 关于ASP.NET中TreeView用法的一个小例子
- 一个简单的iTextSharp的ASP.NET的例子(根据iText的jsp版本转换而来)
- 一个基于Asp.Net MVC的权限方案
- 关于ASP.NET中TreeView用法的一个小例子
- ASP.NET Zero--14.一个例子(7)商品分类管理-分类搜索及分页
- 使用asp.net从零开始制作设计一个网站之一
- asp.net通用权限设计思想雏形
- [ASP.NET 设计模式] 用Visual Studio2010搭建一个简单的分层结构示例Step by Step —— 04 数据访问层