位运算和权限管理系统

在Linux文件系统中,用户对文件或目录有:执行三种权限,分别使用数字:421三个数字。三者之间可任意组合,如:用户拥有所有权限,则用数字7表示(4+2+1=7);用户拥有读、写权限则用数字6表示(4+2=6)。可以看出,基于数字加减的权限设置在使用中非常便利。其对权限的控制,本质上是基于位运算实现的。掌握位运算,不仅可以更加深入的理解Linux权限控制,更可以在自己项目中实现简单高效的、基于位运算的权限管理系统。

  1. Linux基于位运算的权限控制
  2. 或运算实现权限的添加
  3. 与运算实现权限的判断
  4. 非运算实现权限的减少
  5. 位移与权限码

1. Linux基于位运算的权限控制

Linux权限控制是基于位运算实现的。

在Linux权限系统中,执行权限分别对应三个状态位:

读   写   执行      二进制     十进制
0    0    1   ==>   001  ==>  1
0    1    0   ==>   010  ==>  2
1    0    0   ==>   100  ==>  4
0    1    1   ==>   011  ==>  3
1    0    1   ==>   101  ==>  5
1    1    0   ==>   110  ==>  6
1    1    1   ==>   111  ==>  7

如上所示,“执行”权限使用二进制为001,即:十进制1。“写入”权限使用二进制为010,即:十进制2。“读取”权限使用二进制为100,即:十进制4

2. 或运算实现权限的添加

增加权限使用|)运算实现。

如,为用户增加“读取”、“写入”两种权限

读   写   执行      二进制     十进制
0    1    0   ==>   010  ==>  2
1    0    0   ==>   100  ==>  4
1    1    0   ==>   110  ==>  6  // 或(|)运算结果

“读写”两种权限,权限码为6110),其由权限码2010)和4100)进行|)运算后实现,即:6 = 2|4,也可以由6=2+4计算得出。

3. 与运算实现权限的判断

在需要进行用户权限判断时,可以使用&)运算判断用户是否据有某项权限。

如,判断权限码为6用户是否有读取权限:

读   写   执行      二进制     十进制
1    1    0   ==>   110  ==>  6
1    0    0   ==>   100  ==>  4
1    0    0   ==>   100  ==>  4  // 与(&)运算结果

权限码6110)和4100)的与运算结果为4,即:4=6&4

判断权限码为6用户是否有执行权限:

读   写   执行      二进制      十进制
1    1    0   ==>   110   ==>  6
0    0    1   ==>   001   ==>  1
0    0    0   ==>   000   ==>  0  // 与(&)运算结果

权限码6110)和1001)的与运算结果为0,即:0=6&1

根据与运算的计算规律,当运算结果为所要判断权限本身值时,我们可以认为用户具有这个权限。而当运算结果为 0 时,我们可以认为用户不具有这个权限。

4. 非运算实现权限的减少

位运算同样可以实现用户权限的减少,减少用户权限使用^)运算。

如,将权限码为7用户,移除执行权限:

读   写   执行      二进制      十进制
1    1    1   ==>   111   ==>  7
0    0    1   ==>   001   ==>  1
1    1    0   ==>   110   ==>  6  // 非(^)运算结果

权限码7111)和1001)的非运算结果为6,即:6=7^1,也可以由6=7-1计算得出。

5. 位移与权限码

从上面的介绍可以看出,在权限管理系统中每操作的权限码都是唯一的。而基于位运算的权限管理系统,要求每个权限码的二进制数形式,都只能有一位值为1

所使用的权限码,可以将前一个权限码``左位移一位得到下一个权限码,即:

  • 权限码1001),即:20
  • 2=1<<1,即:将001左移1位为010,也即:由20变为21
  • 4=2<<1,即:将010左移1位为100,也即:由21变为22
  • 8=4<<1,即:将100左移1位为1000,也即:由22变为23

简单的说,权限码都是2的幂数2<sup>0</sup>、2<sup>1</sup>、2<sup>2</sup>、2<sup>3</sup>、……2<sup>n</sup>依次对应权限码1、2、4、8……n

相关说明

基于位运算的权限管理,其运算运算对象是二进制数,优点是:运算速度快、效率高、节省存储空间、对权限控制非常灵活。所有语言都提供了位运算符,我们可以在不同语言实现的系统、甚至数据库中使用位运算实现对用户权限的管理。

位运算也有一些局限性,随着权限码增加,数据长度也相应的增长。这就要求权限码不能超过计算本身运算长度,在数据库中存储权限码时,权限码长度也不能的超过所使用数据类型。如:在32位系统中不能超过2<sup>32</sup>,也就是权限数量不能多于32个。而mySQL数据库的BIGINT,其存储空间为8Byte,使用BIGINT存储存储码时,权限数不能多于64个(8*8-1)。

简述RBAC基于角色的访问控制系统 (Role-Based Access Control)

每个权限增加了一个权限位,用作分级
permission表
id            name            method/url          value         Position
1            查看帖子           get                   1              0
2            发布帖子           post                  2              0 
3            修改帖子           update                4              0
4            删除帖子           delete                8              0
5            新增用户           addUser               1              1

角色对应表

id     uid   perId   permission_sum

1      1        1       {"0":[2,3,4]}

2       1       3      {"0":[{"0":[1,2,3]}, {"1":[1,2,3]},  {"2":[1,2,3]} ]}

permission_sum权限位分类

{
    "0":[
        {
            "0":[
                1,
                2,
                3
            ]
        },
        {
            "1":[
                1,
                2,
                3
            ]
        },
        {
            "2":[
                1,
                2,
                3
            ]
        }
    ]
}
public class User {​    
    private Integer  userId;    
    private String name;    
    private  String password;
   
}

 ​public boolean hasPermission(Permission permission){        
    int position = permission.getPosition();        
    long number = permission.getPermissionNum();        
    return !((permissionSum[position] & number) == 0);    
  }   

由于目前时间,没有详细设计,提供一个思路,具体实现是要再进一步确认;


image.png

每个用户的权限值就需要用一个数组来存储,其下标为0的对应着权限位为0的权限值和,
转自 : https://itbilu.com/other/relate/4yJxR6awl.html#linux-bit
https://www.zhihu.com/question/275852963/answer/383522729
https://blog.csdn.net/followMyInclinations/article/details/72123429
https://mp.weixin.qq.com/s/reKtFpQByDcAtzinobNq_Q

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 159,716评论 4 364
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 67,558评论 1 294
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 109,431评论 0 244
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 44,127评论 0 209
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 52,511评论 3 287
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 40,692评论 1 222
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 31,915评论 2 313
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 30,664评论 0 202
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 34,412评论 1 246
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 30,616评论 2 245
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 32,105评论 1 260
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 28,424评论 2 254
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 33,098评论 3 238
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 26,096评论 0 8
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 26,869评论 0 197
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 35,748评论 2 276
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 35,641评论 2 271

推荐阅读更多精彩内容