知识大全 Java通用权限控制算法

Posted 权限

篇首语:智慧并不产生于学历,而是来自对于知识的终生不懈的追求。本文由小常识网(cha138.com)小编为大家整理,主要介绍了知识大全 Java通用权限控制算法相关的知识,希望对你有一定的参考价值。

Java通用权限控制算法  以下文字资料是由(全榜网网www.cha138.com)小编为大家搜集整理后发布的内容,让我们赶快一起来看一下吧!

  一种常用的权限控制算法的实现 参考LINUX/UNIX权限编码

  这里笔者介绍一种很常用 也比较专业的权限控制思路

  要换成其他的语言主 自己转一下就可以了

  这里用java语言描述 其实都差不多的

  为了方便起见 我们这里定义a^b为 a的b次方

  这里 我们为每一个操作设定一个唯一的整数值 比如

  删除A---

  修改A---

  添加A---

  删除B---

  修改B---

  添加B---

  ……

  理论上可以有N个操作 这取决于你用于储存用户权限值的数据类型了

  如果用户有权限

  添加A---

  删除B---

  修改B---

  那用户的权限值 purview = ^ + ^ + ^ = 就是 的权的和 化成二进制可以表示为

  这样 如果要验证用户是否有删除B的权限 就可以通过位与运算来实现

  在JAvA里 位与运算运算符号为& 即是

  int value = purview &((int)Math pow( ));

  你会发现 当用户有操作权限时 运算出来的结果都会等于这个操作需要的权限值!

  原理

  位与运算 顾名思义就是对位进行与运算

  以上面的式子为例 purview & ^ 也就是  &

  将它们化成二进制有

  

  &

  

   == (十进制) ==  ^

  同理 如果要验证是否有删除A--- 的权限

  可以用 purview &((int)Math pow( ));

  即

  

  &

  

   == (十进制)  !=  ^

  这种算法的一个优点是速度快

  可以同时处理N个权限

  如果想验证是否同时有删除A--- 和删除B--- 的权限 可以用

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

  设置多角色用户 根据权限值判断用户的角色

  下面提供一个java的单操作权限判断的代码

  //userPurview是用户具有的总权限

  //optPurview是一个操作要求的权限为一个整数(没有经过权的!)

  public static boolean checkPower(int userPurview int optPurview)

  

  int purviewValue = (int)Math pow( optPurview);

  return (userPurview & purviewValue) == purviewValue;

  

  当然 多权限的验证只要扩展一下就可以了

  几点注意事项

  首先 一个系统可能有很多的操作

  因此 请建立数据字典 以便查阅 修改时使用

  其次 如果用数据库储存用户权限 请注意数值的有效范围

  操作权限值请用唯一的整数!

  public class Limits

  /**

  * 常规信息下发

  */

  public static final int CGXX_XF = ;

  /**

  * 常规信息列表

  */

  public static final int CGXX_LB = ;

  /**

  * 常规信息审核

  */

  public static final int CGXX_SH = ;

  /**

  * 包月用户查看

  */

  public static final int BYYH_CK = ;

  /**

  * 违章点播统计

  */

  public static final int WZDB_TJ = ;

  /**

  * 定制提取详细

  */

  public static final int DZTQ_XX = ;

  /**

  * 请求记录

  */

  public static final int QQJL = ;

  /**

  * 管理员权限

  */

  public static final int GLY_QX = ;

  /**

  * 验证权限

  * @param limitsSum 权限总和 权限总和 为每个权限的 次方相加

  * @param checkInt 具体权限

  * @return

  */

  public static boolean checkLimits(int limitsSum int checkInt)

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

  

  /**

  * 生成权限总值

  * @param limits

  * @return

  */

  public static int createLimits(String[] limits)

  int limitsSum = ;

  for (int i = ; i < limits length; i++)

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

  

  return limitsSum;

  

cha138/Article/program/Java/hx/201311/25604

相关参考