java权限算法.docVIP

  • 5
  • 0
  • 约1.18千字
  • 约 3页
  • 2018-11-24 发布于河南
  • 举报
java权限算法

向大家介绍一种很不错,也是Linux中的权限管理算法。   定义a^b为:a的b次方   假如,我们为每一个操作设定一个唯一的整数值,比如:   删除A---0   修改A---1   添加A---2   删除B---3   修改B---4   添加B---5   。。。   理论上可以有N个操作,这取决于你用于储存用户权限值的数据类型了。   这样,如果用户有权限:添加A---2;删除B---3;修改B---4   那用户的权限值 purview =2^2+2^3+2^4=28,也就是2的权的和了   化成二进制可以表示为11100   如果要验证用户是否有删除B的权限,就可以通过位与运算来实现。   在Java里,位与运算运算符号为   即是:int value = purview ((int)Math.pow(2,3));   你会发现,当用户有操作权限时,运算出来的结果都会等于这个操作需要的权限值!   原理:   位与运算,顾名思义就是对位进行与运算:   以上面的式子为例:purview 2^3 也就是 288   将它们化成二进制有   11100    01000   -------------------   01000 == 8(十进制) == 2^3   同理,如果要验证是否有删除A---0的权限   可以用:purview ((int)Math.pow(2

您可能关注的文档

文档评论(0)

1亿VIP精品文档

相关文档