权限管理的一点思路

在一个WinForm项目中的权限管理部分,使用MDI窗体,从主窗体上的menu打开MDI子窗体,对每个子窗体都有一个权限ID,打开时要判断user是否有权限,为了把校验这部分作的通用些,使用了下面的实现:
1.定义一个接口IRight,里面只有一个方法GetRightID,入下:

interface  IRight
{
    
string GetRightID();
}

2.每个MDI子窗体都继承这个接口,在实现GetRightID中返回一个权限ID,例如:
public   string  GetRightID()
{
     
return "Customer";
}

3.在主窗体上打开子窗体的地方,加上对权限的检验,例如:
Form2 f  =   new  Form2();
if  ( UserHaveRight(GetUserRights( " Admin " ,f)) )
{
     f.MDIParent 
= this;
     f.Show();
}

else
{
     f.Dispose();
}

其中调用的两个函数:
private   bool  UserHaveRight(ArrayList currentUserRights, IRight formWillOpen)
{
    
if ( currentUserRights.Contains(formWillOpen.GetRightID()) )
    
{
         
return true;
    }

    
else
    
{
         
return false;
    }

}

private  ArrayList GetUserRight( string  userID )
{
    ArrayList result 
= new ArrayList();
    result.Add(
"Customer");
    result.Add(
"Premise");
    
return result;
}


刚开始时是把GetRightID放在一个窗体基类里,MDI子窗体充这个基类继承然后override这个方法,后来作成从接口继承是考虑到这个接口还可以用在控件上,也就不仅仅是页面级的权限控制。

目前还有一个问题是,在检验时要先生成子窗体的实例,如果检验不通过还要释放掉,就有资源浪费,好在检查权限不通过的情况不多,目前这个办法还是可以接受的。如果有更好的办法,还请大家不吝赐教。

由于公司不能上网,这个post是我写在纸上到网吧里敲上来的 代码只是说明问题,没有编译过,象GetUserRight也只是象征性的返回一个权限ID的集合,实际中有可能是DataSet或其他的。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值