備注學(xué)院

          LuLu

            BlogJava :: 首頁 :: 新隨筆 :: 聯(lián)系 :: 聚合  :: 管理 ::
            5 隨筆 :: 50 文章 :: 16 評論 :: 0 Trackbacks
          這里筆者介紹一種很常用,也比較專業(yè)的權(quán)限控制思路。這里用java語言描述,其實都差不多的。要換成其他的語言主,自己轉(zhuǎn)一下就可以了。為了方便起見,我們這里定義a^b為:a的b次方。這里,我們?yōu)槊恳粋€操作設(shè)定一個唯一的整數(shù)值,比如:

          刪除A---0
          修改A---1
          添加A---2

           

          刪除B---3
          修改B---4
          添加B---5

          ……

            理論上可以有N個操作,這取決于你用于儲存用戶權(quán)限值的數(shù)據(jù)類型了。

            這樣,如果用戶有權(quán)限:添加A---2;刪除B---3;修改B---4。那用戶的權(quán)限值 purview =2^2+2^3+2^4=28,也就是2的權(quán)的和了。化成二進(jìn)制可以表示為11100。這樣,如果要驗證用戶是否有刪除B的權(quán)限,就可以通過位與運算來實現(xiàn)。在Java里,位與運算運算符號為&,即是:

          int value = purview &((int)Math.pow(2,3));

            你會發(fā)現(xiàn),當(dāng)用戶有操作權(quán)限時,運算出來的結(jié)果都會等于這個操作需要的權(quán)限值!

            原理:

            位與運算,顧名思義就是對位進(jìn)行與運算:

            以上面的式子為例:purview & 2^3 也就是 28&8

            將它們化成二進(jìn)制有

           11100
          & 01000
          -------------------
            01000 == 8(十進(jìn)制) == 2^3

            同理,如果要驗證是否有刪除A---0的權(quán)限

            可以用:purview &((int)Math.pow(2,0));

            即:

           11100
          & 00001
          ------------------------
            00000 == 0(十進(jìn)制)  != 2^0

            這種算法的一個優(yōu)點是速度快。可以同時處理N個權(quán)限。如果想驗證是否同時有刪除A---0和刪除B---3的權(quán)限,可以用purview&(2^0+2^3)==(2^0+2^3)?true:false;設(shè)置多角色用戶。根據(jù)權(quán)限值判斷用戶的角色。

            下面提供一個java的單操作權(quán)限判斷的代碼:

          //userPurview是用戶具有的總權(quán)限
          //optPurview是一個操作要求的權(quán)限為一個整數(shù)(沒有經(jīng)過權(quán)的!)
          public static boolean checkPower(int userPurview, int optPurview)
          {
            int purviewValue = (int)Math.pow(2, optPurview);
            return (userPurview & purviewValue) == purviewValue;
          }

            當(dāng)然,多權(quán)限的驗證只要擴展一下就可以了。

            幾點注意事項:首先,一個系統(tǒng)可能有很多的操作,因此,請建立數(shù)據(jù)字典,以便查閱,修改時使用。其次,如果用數(shù)據(jù)庫儲存用戶權(quán)限,請注意數(shù)值的有效范圍。操作權(quán)限值請用唯一的整數(shù)! 


          posted on 2008-03-30 10:33 smildlzj 閱讀(260) 評論(0)  編輯  收藏 所屬分類: JavaWeb開發(fā)
          主站蜘蛛池模板: 恭城| 万州区| 枣阳市| 广河县| 普格县| 宁安市| 平果县| 宜城市| 新宁县| 郯城县| 余江县| 金平| 中宁县| 泌阳县| 汝州市| 长兴县| 叶城县| 当涂县| 延川县| 双辽市| 营山县| 车致| 济宁市| 香格里拉县| 儋州市| 天水市| 上高县| 红安县| 德保县| 冕宁县| 红河县| 同德县| 新河县| 克什克腾旗| 富宁县| 岗巴县| 岳阳市| 上思县| 肇州县| 和平区| 旬邑县|