亚洲AV日韩AⅤ综合手机在线观看,激情婷婷久久综合色,欧美色五月婷婷久久,久久国产精品99久久人人澡

  • <abbr id="uk6uq"><abbr id="uk6uq"></abbr></abbr>
  • <tbody id="uk6uq"></tbody>
  • Java通用權(quán)限控制的算法

    時(shí)間:2020-10-06 14:55:59 ACCP培訓(xùn) 我要投稿

    關(guān)于Java通用權(quán)限控制的算法

      一種常用的權(quán)限控制算法的實(shí)現(xiàn),參考LINUX/UNIX權(quán)限編碼,具體內(nèi)容是怎么樣的?一起和小編學(xué)習(xí)學(xué)習(xí)吧!

      這里用java語(yǔ)言描述,其實(shí)都差不多的。

      為了方便起見(jiàn),我們這里定義a^b為:a的b次方。

      這里,我們?yōu)槊恳粋(gè)操作設(shè)定一個(gè)唯一的整數(shù)值,比如:

      刪除A---0

      修改A---1

      添加A---2

      刪除B---3

      修改B---4

      添加B---5

      ……

      理論上可以有N個(gè)操作,這取決于你用于儲(chǔ)存用戶權(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。

      這樣,如果要驗(yàn)證用戶是否有刪除B的權(quán)限,就可以通過(guò)位與運(yùn)算來(lái)實(shí)現(xiàn)。

      在JAvA里,位與運(yùn)算運(yùn)算符號(hào)為&,即是:

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

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

      原理:

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

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

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

      11100

      & 01000

      -------------------

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

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

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

      即:

      11100

      & 00001

      ------------------------

      00000 == 0(十進(jìn)制)  != 2^0

      這種算法的一個(gè)優(yōu)點(diǎn)是速度快。

      可以同時(shí)處理N個(gè)權(quán)限。

      如果想驗(yàn)證是否同時(shí)有刪除A---0和刪除B---3的權(quán)限,可以用

      purview&(2^0+2^3)==(2^0+2^3)?true:false;

      設(shè)置多角色用戶。根據(jù)權(quán)限值判斷用戶的角色。

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

      //userPurview是用戶具有的總權(quán)限

      //optPurview是一個(gè)操作要求的'權(quán)限為一個(gè)整數(shù)(沒(méi)有經(jīng)過(guò)權(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)限的驗(yàn)證只要擴(kuò)展一下就可以了。

      幾點(diǎn)注意事項(xiàng):

      首先,一個(gè)系統(tǒng)可能有很多的操作,

      因此,請(qǐng)建立數(shù)據(jù)字典,以便查閱,修改時(shí)使用。

      其次,如果用數(shù)據(jù)庫(kù)儲(chǔ)存用戶權(quán)限,請(qǐng)注意數(shù)值的有效范圍。

      操作權(quán)限值請(qǐng)用唯一的整數(shù)!

      public class Limits {

      /**

      * 常規(guī)信息下發(fā)

      */

      public static final int CGXX_XF = 0;

      /**

      * 常規(guī)信息列表

      */

      public static final int CGXX_LB = 1;

      /**

      * 常規(guī)信息審核

      */

      public static final int CGXX_SH = 2;

      /**

      * 包月用戶查看

      */

      public static final int BYYH_CK = 3;

      /**

      * 違章點(diǎn)播統(tǒng)計(jì)

      */

      public static final int WZDB_TJ = 4;

      /**

      * 定制提取詳細(xì)

      */

      public static final int DZTQ_XX = 5;

      /**

      * 請(qǐng)求記錄

      */

      public static final int QQJL = 6;

      /**

      * 管理員權(quán)限

      */

      public static final int GLY_QX = 7;

      /**

      * 驗(yàn)證權(quán)限

      * @param limitsSum 權(quán)限總和 權(quán)限總和 為每個(gè)權(quán)限的3次方相加

      * @param checkInt 具體權(quán)限

      * @return

      */

      public static boolean checkLimits(int limitsSum, int checkInt){

      return (limitsSum & (1 << checkInt)) > 0;

      }

      /**

      * 生成權(quán)限總值

      * @param limits

      * @return

      */

      public static int createLimits(String[] limits){

      int limitsSum = 0;

      for (int i = 0; i < limits.length; i++) {

      limitsSum += (1 << Integer.parseInt(limits[i]));

      }

      return limitsSum;

      }

    【關(guān)于Java通用權(quán)限控制的算法】相關(guān)文章:

    java排序算法大全06-07

    java算法字符組合排序06-07

    java五種排序算法匯總10-01

    Java語(yǔ)言4種訪問(wèn)權(quán)限修飾符11-06

    最全的java隨機(jī)數(shù)生成算法05-15

    Java認(rèn)證輔導(dǎo):Java實(shí)現(xiàn)二叉樹(shù)遍歷算法11-29

    Java語(yǔ)言中的流程控制11-02

    JAVA認(rèn)證基礎(chǔ)知識(shí):近似算法(格雷厄姆算法)簡(jiǎn)介11-18

    Linux操作系統(tǒng)中超級(jí)權(quán)限控制的應(yīng)用解析06-08