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

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里。
另一种方法时,在服务器上判断,当前用户是否有某个权限。

 
IdParentIdCodeFullNameNavigateUrl
10000003 整体信息化系统整体信息化系统 
1000000510000004FrmRequestAnAccount申请用户账户 
1000000710000004FrmStaffAddressEdit我的联系方式 
1000000810000004FrmStaffAddressAdmin内部通讯录 
1000001510000004Appliction业务应用 
1000001610000004FrmMessageSend发送消息 
1000001710000004FrmMessage即时通讯 
1000002210000004FrmAboutThis关于本软件 
1000002410000004FrmUserChangePassword修改密码 
1000409910004141用户下订单用户下订单Modules/Convenience/YongHuDingDan/YongHuDingDanTianJia.aspx
1000410010004141用户订单确认用户订单确认Modules/Convenience/YongHuDingDan/YongHuDingDanDaiQueRen.aspx
1000410110004142订单状态查询订单配额审核查询Modules/Convenience/YongHuDingDan/YongHuDingDanPeiEYiQueRen.aspx
1000410210004140历史订单历史订单Modules/Convenience/YongHuDingDan/YongHuDingDanChaXun.aspx
1000410310004183订单到货确认订单到货确认Modules/Convenience/YongHuDingDan/YongHuDingDanDaoHuoQueRen.aspx
1000414010004150CSa01订单管理Modules/Convenience/YongHuDingDan/YongHuDingDanYiQueRen.aspx
1000414110004140用户订单用户订单Modules/Convenience/YongHuDingDan/YongHuDingDanYiQueRen.aspx
1000414210004140订单状态订单状态Modules/Convenience/YongHuDingDan/YongHuDingDanPeiHuoYiQueRen.aspx
1000414410004142订单结算状态查询订单结算状态查询Modules/Convenience/YongHuDingDan/YongHuDingDanJieSuanYiQueRen.aspx
1000414510004142订单配货状态查询订单配货状态查询Modules/Convenience/YongHuDingDan/YongHuDingDanPeiHuoYiQueRen.aspx
1000414810004102订单统计汇总历史订单查询Modules/Convenience/YongHuDingDan/YongHuDingDanChaXun.aspx
1000415010000003终端功能终端功能 
1000417610004141用户已确认订单用户已确认订单Modules/Convenience/YongHuDingDan/YongHuDingDanYiQueRen.aspx
1000418310004140订单到货订单到货Modules/Convenience/YongHuDingDan/YongHuDingDanDaoHuoQueRen.aspx
1000441010004141用户已取消订单用户已取消订单 
1000442910000004FrmCodeBuilder代码生成器 

 

 


二:用户所拥有的权限列表(用户-权限,角色-权限,权限本身是否公开属性,权限的父子归属关系,权限是否有效)按以上结合最终计算出所拥有的权限集合
IdParentIdCodeFullName
100002590PermissionAdmin通用权限解决方案
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楼[楼主]  回复 引用 查看   

@熊哥

那也不按一下推荐,有点儿小气,呵呵。

#3楼  回复 引用 查看   

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

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

@ygcao

你具体详细点儿指的是什么方面的?我没能看明白您的意思。

#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里都需要兼容,那就可能需要多考虑几个因素了。

#8楼  回复 引用 查看   

@吉日嘎拉 不仅权限管理


这个不能简化吗?

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

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

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

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

@szyicol

这个可以写构造函数的,想简化,那不是很容易的事情吗?
而且还可以进行封装的,我是把最复杂的情况考虑了,才写了这样的。

#10楼  回复 引用 查看   

@吉日嘎拉 不仅权限管理

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


2010-07-09 17:05 | szyicol       

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

@szyicol

写那么简单了,人家要处理复杂的问题怎么弄?

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

@szyicol

也不能只考虑最简单的情况吧? 把最复杂的情况写下来了,其他的人家自己可以自由简化的啦。

#13楼  回复 引用 查看   

@吉日嘎拉 不仅权限管理


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

#14楼  回复 引用 查看   

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

#15楼  回复 引用 查看   

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

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

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

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

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

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

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

#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

有自己的一套简易工作流组件。
  • 1
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
实现一个图书管理系统,需要考虑以下几个方面: 1. 数据库设计 需要设计图书、用户、借阅记录等几个主要表,并确定它们之间的关系。可以使用 Microsoft SQL Server 等关系型数据库管理系统存储数据。 2. 界面设计 需要设计用户登录、图书查询、借阅归还等功能的界面。可以使用 ASP.NET Web Forms 或 ASP.NET MVC 框架开发网页,并使用 HTML、CSS 和 JavaScript 等前端技术渲染页面。 3. 后端逻辑 需要编写 C# 代码实现用户登录、图书查询、借阅归还等功能的后端逻辑。可以使用 ADO.NET 或 Entity Framework 等技术访问数据库,并根据用户的请求进行相应的操作。 下面是一个简单的示例: 1. 数据库设计 创建三张表 Book、User 和 Borrow,它们之间的关系如下: Book(图书表): - Id(主键) - Name(图书名称) - Author(作者) - PublishDate(出版日期) - Price(价格) User(用户表): - Id(主键) - Username(用户名) - Password(密码) - Email(邮箱) Borrow(借阅记录表): - Id(主键) - UserId(外键,关联用户表) - BookId(外键,关联图书表) - BorrowDate(借阅日期) - ReturnDate(归还日期) 2. 界面设计 可以创建以下几个页面: - 登录页面(Login.aspx) - 注册页面(Register.aspx) - 主页(Default.aspx) - 图书查询页面(Books.aspx) - 借阅归还页面(Borrow.aspx) 其登录页面和注册页面需要使用 ASP.NET Web Forms 提供的控件实现用户输入和提交。主页需要显示当前用户的借阅记录和操作按钮。图书查询页面需要使用 ASP.NET GridView 控件显示图书列表,并提供搜索和排序功能。借阅归还页面需要显示当前借阅的图书,以及提供借阅和归还按钮。 3. 后端逻辑 可以在代码实现以下几个功能: - 用户登录和注册 使用 ASP.NET 提供的 MembershipProvider 实现用户验证和注册功能。 - 图书查询和借阅归还 使用 ADO.NET 或 Entity Framework 访问数据库,并根据用户的请求进行相应的操作。 - 页面跳转和数据传递 使用 ASP.NET 提供的跳转方法和 Session 对象实现页面之间的跳转和数据传递。 以上是一个简单的图书管理系统的实现方式,可以根据实际需求进行调整和扩展。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值