欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

.net 运用二进制位运算进行数据库权限管理

程序员文章站 2024-03-04 22:53:54
权限分为增、删、改、查,数据库插入拥有权限的数值的和。比如拥有增加和修改功能,就是:permissions.add+permissions.mod,结果值为:5。 那么判...

权限分为增、删、改、查,数据库插入拥有权限的数值的和。比如拥有增加和修改功能,就是: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;
    }