.net 运用二进制位运算进行权限管理
第一次写博客,加油!
权限分为增、删、改、查,数据库插入拥有权限的数值的和。比如拥有增加和修改功能,就是:Permissions.Add+Permissions.Mod,结果值为:5。
那么判断是否有此权限时,就可以调用IsPermission(value, per)方法。假设结果值为:5,那么如果“添加权限”调用就是:IsPermission(5, Permissions.Add),
返回结果为true;如果“删除权限”调用就是:IsPermission(5, Permissions.Del),返回结果为false。
公用类:
/// <summary> /// 权限设置二进制 /// </summary> [Flags] public enum Permissions { Add = 1, Del = 2, Mod = 4, Select = 8 } /// <summary> /// 判断是否拥有此权限,false=不存在,true=存在 /// </summary> /// <param name="value">权限类型值</param> /// <param name="per">操作类型:增删改查</param> /// <returns>判断是否拥有此权限,false=不存在,true=存在</returns> public static bool IsPermission(int value, Permissions per) { bool bo = false;//默认不存在 switch (per) { case Permissions.Add: if ((value & Convert.ToInt32(Permissions.Add)) == Convert.ToInt32(Permissions.Add))//运算 (value & 1)==1 bo = true; break; case Permissions.Del: if ((value & Convert.ToInt32(Permissions.Del)) == Convert.ToInt32(Permissions.Del))// bo = true; break; case Permissions.Mod: if ((value & Convert.ToInt32(Permissions.Mod)) == Convert.ToInt32(Permissions.Mod))// bo = true; break; case Permissions.Select: if ((value & Convert.ToInt32(Permissions.Select)) == Convert.ToInt32(Permissions.Select))// bo = true; break; } return bo; }
有不足之处,请大侠们指出。
下面是扩充方法:实现用户继承角色权限,分配用户权限时,加载角色权限,但是不能更改角色权限。
首先判断权限类型,然后传入权限值、操作类型、返回参数(角色权限置灰)。
扩展方法:
/// <summary> /// 复选框角色判定 /// </summary> /// <param name="right_type">权限类型,为0时,未有权限;为1或3时,有角色权限;为2时,有用户权限;为3时,同时拥有角色权限,用户权限,视为拥有角色权限</param> /// <param name="roleValue">角色权限值</param> /// <param name="userValue">用户权限值</param> /// <param name="per">权限类型:增删改查</param> /// <param name="isEnabled">是否为角色权限,如果为角色权限置灰。true=否,false=是</param> /// <returns></returns> public static bool IsPermissionCheck(int right_type, int roleValue, int userValue, Permissions per, ref bool isEnabled) { bool bo = false; isEnabled = true; switch (right_type) { case 1: bo = IsPermission(roleValue, per);//只拥有角色权限 isEnabled = false; break; case 2: bo = IsPermission(userValue, per);//只拥有用户权限 break; case 3: int sumValue = roleValue | userValue;//角色权限或用户权限。合并角色、用户权限 bo = IsPermission(sumValue, per); isEnabled = !IsPermission(roleValue, per); break; } return bo; }