C# ASP.NET 最常用的通用权限的3个方法例子展示(每个功能一行代码实现)

来源:互联网 发布:电玩城源码出售 编辑:程序博客网 时间:2024/06/01 10:37
C# ASP.NET 最常用的通用权限的3个方法例子展示。
在 UserPermission.aspx 的例子如下,原文件的位置如下图:
 
 
参考代码如下:
代码
//------------------------------------------------------------
// All Rights Reserved , Copyright (C) 2010 , Jirisoft , Ltd. 
//------------------------------------------------------------

using System;
using System.IO;
using System.Data;

namespace DotNet.Web.Permission
{
    
using DotNet.Service;
    
using DotNet.Utilities;
    
using Jirisoft.Permission.Model;
    
using Jirisoft.Permission.Business;

    
/// <remarks>
    
/// UserPermission
    
/// 用户当前权限的获取例子
    
/// 
    
/// 修改纪录
    
/// 
    
///    版本:1.0 2010.07.08    JiRiGaLa    写好例子程序方便别人学习。
    
///    
    
/// 版本:1.0
    
/// <author>
    
///        <name>JiRiGaLa</name>
    
///        <date>2010.07.08</date>
    
/// </author> 
    
/// </remarks>
    public partial class UserPermission : BasePage
    {
        
protected void Page_Load(object sender, EventArgs e)
        {
            
// 当然是用户需要登录,否则哪里能知道,现在是判断谁的权限啊?
            this.UserInfo = Utilities.Login("Jirigala_Bao@Hotmail.com", String.Empty);
            
            
// 1 判断用户是否有某个操作权限(在服务器上判断)
            
// 访问职员的身份证列字段的操作权限
            string permissionItemCode = "Staff.Column.IDCard.Access";
            ServiceManager.Instance.PermissionService.IsAuthorizedByUser(
this.UserInfo, this.UserInfo.Id, permissionItemCode);

            
// 2 获取用户模块菜单列表
            this.GetUserModules();

            
// 3 获取用户权限列表
            this.GetUserPermission();
        }

        
/// <summary>
        
/// 2 获取用户模块菜单列表
        
/// </summary>
        private void GetUserModules()
        {
            
// 就一行代码,就可以获取当前用户的所有可以访问的模块,然后自己想怎么处理就处理,例如变成树形菜单等等
            DataTable dtUserModule = ServiceManager.Instance.PermissionService.GetModuleDTByUser(this.UserInfo, this.UserInfo.Id);
            
this.grvUserModules.DataSource = dtUserModule;
            
this.grvUserModules.DataBind();
        }

        
/// <summary>
        
/// 3 获取用户权限列表
        
/// </summary>
        private void GetUserPermission()
        {
            
// 就一行代码,就可以获取当前用户的所拥有的权限列表
            DataTable dtUserPermission = ServiceManager.Instance.PermissionService.GetPermissionDTByUser(this.UserInfo, this.UserInfo.Id);
            
this.grvUserPermission.DataSource = dtUserPermission;
            
this.grvUserPermission.DataBind();
        }
    }
}


一:用户可以访问的模块菜单(用户-菜单,角色-菜单,用户-角色,权限-菜单,菜单本身是否公开属性,菜单的父子归属关系,菜单是否有效)按以上结合最终计算出所能访问的菜单集合,当然对超级管理员进行优化处理,简化权限判断过程,提高程序运行效率
有一种方法是,一次性把用户的所有权限都获得,放在客户端或者Seesion里。
另一种方法时,在服务器上判断,当前用户是否有某个权限。

 
IdParentIdCodeFullNameNavigateUrl10000003 整体信息化系统整体信息化系统 1000000510000004FrmRequestAnAccount申请用户账户 1000000710000004FrmStaffAddressEdit我的联系方式 1000000810000004FrmStaffAddressAdmin内部通讯录 1000001510000004Appliction业务应用 1000001610000004FrmMessageSend发送消息 1000001710000004FrmMessage即时通讯 1000002210000004FrmAboutThis关于本软件 1000002410000004FrmUserChangePassword修改密码 1000409910004141用户下订单用户下订单Modules/Convenience/YongHuDingDan/YongHuDingDanTianJia.aspx1000410010004141用户订单确认用户订单确认Modules/Convenience/YongHuDingDan/YongHuDingDanDaiQueRen.aspx1000410110004142订单状态查询订单配额审核查询Modules/Convenience/YongHuDingDan/YongHuDingDanPeiEYiQueRen.aspx1000410210004140历史订单历史订单Modules/Convenience/YongHuDingDan/YongHuDingDanChaXun.aspx1000410310004183订单到货确认订单到货确认Modules/Convenience/YongHuDingDan/YongHuDingDanDaoHuoQueRen.aspx1000414010004150CSa01订单管理Modules/Convenience/YongHuDingDan/YongHuDingDanYiQueRen.aspx1000414110004140用户订单用户订单Modules/Convenience/YongHuDingDan/YongHuDingDanYiQueRen.aspx1000414210004140订单状态订单状态Modules/Convenience/YongHuDingDan/YongHuDingDanPeiHuoYiQueRen.aspx1000414410004142订单结算状态查询订单结算状态查询Modules/Convenience/YongHuDingDan/YongHuDingDanJieSuanYiQueRen.aspx1000414510004142订单配货状态查询订单配货状态查询Modules/Convenience/YongHuDingDan/YongHuDingDanPeiHuoYiQueRen.aspx1000414810004102订单统计汇总历史订单查询Modules/Convenience/YongHuDingDan/YongHuDingDanChaXun.aspx1000415010000003终端功能终端功能 1000417610004141用户已确认订单用户已确认订单Modules/Convenience/YongHuDingDan/YongHuDingDanYiQueRen.aspx1000418310004140订单到货订单到货Modules/Convenience/YongHuDingDan/YongHuDingDanDaoHuoQueRen.aspx1000441010004141用户已取消订单用户已取消订单 1000442910000004FrmCodeBuilder代码生成器 

 

 


二:用户所拥有的权限列表(用户-权限,角色-权限,权限本身是否公开属性,权限的父子归属关系,权限是否有效)按以上结合最终计算出所拥有的权限集合
IdParentIdCodeFullName100002590PermissionAdmin通用权限解决方案1000056010000259A系统权限配置A系统权限配置1000056410000560ASystem.Admin.AccessA系统访问权限
 

三:当前用户是否有某个权限的判断(用户本身是否超级管理员?)。

            // 1 判断用户是否有某个操作权限(在服务器上判断)
            // 访问职员的身份证列字段的操作权限
            string permissionItemCode = "Staff.Column.IDCard.Access";
            ServiceManager.Instance.PermissionService.IsAuthorizedByUser(this.UserInfo, this.UserInfo.Id, permissionItemCode);

设置asp.net通用权限的界面参考如下:

 

C/S的权限配置管理工具 是提供给项目实施人员使用的,在项目开发的前期是给系统架构师用的。

在数据库管理维护过程中,C/S的配置管理工具是给数据库管理员用的。

用户在管理使用过程中,C/S的配置管理工具是给信息管理员用的。

在软件开发阶段,C/S的管理配置工具是给开发人员项目经理测试人员用的。

在开发阶段,底层的API,接口函数是给开发人员调用的。

在售前,给客户演示时,C/S的管理配置工具是给客户展示实力用的。

在售前,通用权限管理说明文档是市场销售人员给客户写方案用的。

 

ASP.NET C#通用权限管理系统,是软件公司老板防止开发人员每个人搞一套,是为了提高公司的软件开发类项目互相兼容性差,互相集成性。同时是可以达到快速见效,有个牢靠的底层,防止开发人员流动、走失后导致整个项目乱套用的。使用成熟的组件,可以提高工作效率,可以有效积累劳动成果,防止在没必要的事情上瞎折腾,浪费时间,浪费生命。

 

只有执着追求,把一个方向做深做精,做个彻底,才会有希望才能更上一层楼。通用权限管理组件使用说明书V3.0.doc

有1000000人会开发管理软件,但是可能只有100000人会开发成熟的权限系统,只有10000个人能开发出完善的工作流。

 

 

 

将权限管理、工作流管理做到我能力的极致,一个人只能做好那么很少的几件事情。

posted on 2010-07-08 23:23 吉日嘎拉 不仅权通用权限 阅读(658) 评论(21) 编辑 收藏

评论

#1楼  回复 引用 查看    同志你很敬业,支持你。

WINDOWS的权限做的很不错,我们系统就是使用这种方式。

2010-07-08 23:29 | 熊哥      

#2楼[楼主]  回复 引用 查看   

@熊哥

那也不按一下推荐,有点儿小气,呵呵。
2010-07-08 23:40 | 吉日嘎拉 不仅权限管理      

#3楼  回复 引用 查看   

以前你说数据访问的权限控制还不知道如何解决,不知道现在解决没有?
2010-07-09 09:55 | ygcao      

#4楼[楼主]  回复 引用 查看   

@ygcao

你具体详细点儿指的是什么方面的?我没能看明白您的意思。
2010-07-09 11:00 | 吉日嘎拉 不仅权限管理      

#5楼  回复 引用 查看   

// 就一行代码,就可以获取当前用户的所有可以访问的模块,然后自己想怎么处理就处理,例如变成树形菜单等等
DataTable dtUserModule = ServiceManager.Instance.PermissionService.GetModuleDTByUser(this.UserInfo, this.UserInfo.Id);

自相矛盾的代码!!!


1、如果是UserInfo这个类是你平台中的类,既然已经传了UserInfo,为何又要传一个UserInfo类中的Id?类是你自己的,难道不知道UserInfo中有Id这个属性吗?

2、如果UserInfo这个类是开发人员自己定义的,那传这个类进去,有个P用啊!!!!!
2010-07-09 12:01 | szyicol      

#6楼  回复 引用 查看   

@吉日嘎拉 不仅权限管理
现在看你的权限管理是基于功能的,能不能控制到某个功能下面的某些数据的权限。
2010-07-09 12:23 | ygcao      

#7楼[楼主]  回复 引用 查看   

@szyicol

1:大部分情况下,是判断当前操作员有什么权限,特殊情况下,还需要判断,别人有什么权限?当前操作者以外的别人有啥权限?例如别人是否有审核权限?等等。

2:UserInfo 你随便传过去,未必能能在服务器上验证通过的,服务器需要知道,当前是谁在请求?谁在操作。

程序写出来,当然也有他的道理,未必是错的,未必是不正确的,当然有的东西可以简化,有的东西无法简化,简化了,就不能适应各种复杂的应用环境了。

例如B/S里,C/S里都需要兼容,那就可能需要多考虑几个因素了。
2010-07-09 13:26 | 吉日嘎拉 不仅权限管理      

#8楼  回复 引用 查看   

@吉日嘎拉 不仅权限管理


这个不能简化吗?

既然是获取当前用户,起码我觉得完全可以将这个方法重载,而且重载中不需要一句代码。。。。

程序员总是这样,觉得自己写的代码可以适用各种复杂环境,就不理会用户或其它人的感受。

如果你有做过项目经理,或是做过项目实施,肯定不会这样写代码。
2010-07-09 15:36 | szyicol      

#9楼[楼主]  回复 引用 查看   

@szyicol

这个可以写构造函数的,想简化,那不是很容易的事情吗?
而且还可以进行封装的,我是把最复杂的情况考虑了,才写了这样的。
2010-07-09 16:48 | 吉日嘎拉 不仅权限管理      

#10楼  回复 引用 查看   

@吉日嘎拉 不仅权限管理

这么容易的事,都没有做,估计其它的,也就一般


2010-07-09 17:05 | szyicol      

#11楼[楼主]  回复 引用 查看   

@szyicol

写那么简单了,人家要处理复杂的问题怎么弄?
2010-07-09 17:29 | 吉日嘎拉 不仅权限管理      

#12楼[楼主]  回复 引用 查看   

@szyicol

也不能只考虑最简单的情况吧? 把最复杂的情况写下来了,其他的人家自己可以自由简化的啦。
2010-07-09 17:30 | 吉日嘎拉 不仅权限管理      

#13楼  回复 引用 查看   

@吉日嘎拉 不仅权限管理


拜托,我从来没有说只考虑简单,只是说你的这行代码是你不顾其它人的感受而让其它做的多此一举的事。
2010-07-09 18:38 | szyicol      

#14楼  回复 引用 查看   

吉日老师你有没考虑过多账套的处理及权限配置
2010-07-10 20:55 | 佳明      

#15楼  回复 引用 查看   

继承权限(上级拥有下级的所有权限),能否给个思路?
2010-07-10 21:50 | 真名士      

#16楼[楼主]  回复 引用 查看   

这个考虑过的,很早以前,我是做ERP的,所以对多账套,稍微有些了解。

引用佳明:吉日老师你有没考虑过多账套的处理及权限配置

2010-07-11 00:04 | 吉日嘎拉 不仅权限管理      

#17楼[楼主]  回复 引用 查看   

树型结构的权限,正在写,今天写了一天了,再过几天发布博文,以前写好的也有,这次再深入整理了一下,更加系统化一些。

引用真名士:继承权限(上级拥有下级的所有权限),能否给个思路?

2010-07-11 00:04 | 吉日嘎拉 不仅权限管理      

#18楼  回复 引用 查看   

@吉日嘎拉 不仅权限管理

现在很多软件都趋向于围绕这 ERP 来做文章
就相当于有点趋向于BI
不知道吉日老师有没考虑过把Erp里面的一些思路搬进来。我想现在权限比较复杂的应该就是ERP系统了吧。
2010-07-11 08:01 | 佳明      

#19楼  回复 引用 查看   

期待后续文章~
2010-07-11 09:43 | 真名士      

#20楼  回复 引用 查看   

这个系统工作流是怎么实现的?
2010-08-09 13:43 | 风雨者2      

#21楼[楼主]  回复 引用 查看   

@风雨者2

有自己的一套简易工作流组件。
原创粉丝点击