程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 編程語言 >> .NET網頁編程 >> ASP.NET >> ASP.NET基礎 >> .net 運用二進制位運算進行數據庫權限管理

.net 運用二進制位運算進行數據庫權限管理

編輯:ASP.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;
    }

  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved