简单权限控制-8421法则

前言

在系统开发过程中,最常见的一个需求就是权限控制了,大到整个系统的用户权限的管理,小到某个状态下操作权限的判断。

其中最常见的操作就是权限的添加、删除、鉴权等,那么有什么简单的方法可以去控制这些权限呢?

对于复杂的权限控制可以采用 RBAC 方案,这里向大家推荐一种简单方法,来处理简单的权限控制,涉及二进制8421码以及按位与等知识。

模拟需求

假设要对文章进行权限管理,分为新增、查看、修改三个权限。

方案设计

新增 查看 修改
1 2 4

1、把权限对应的值设置如下

新增 查看 修改
1 2 4

2、用户初始权限 authority 设置为 0,也即authority = 0;
3、赋予权限 a 时,先要判断用户是否已经有此权限,若无,则把 a 对应的值与 authority 相加作为用户的当前权限,也即 authority = authority + a;
4、判断用户是否有某个权限 b 的方法

if ( (authority & b) == b){
    //有权限b
}
c = a + b;
if ( (authority & c) == c){
    //同时有权限a和b
}

5、去除权限 a 时,先要判断用户是否已经有此权限,若有,则把 a 对应的值与 authority 相减作为用户的当前权限,也即 authority = authority - a;

原理

我们知道,在计算机里面数据的底层表示都是二进制数,我们可以通过设定每一位表示不同的权限,用0来表示未拥有此权限,1来表示拥有对应权限。

权限 二进制值
查看 001(1)
新增 010(2)
修改 100(4)

例如上面例子中3个权限的情况,我们可以用3位的二进制数来表示其权限,如下

权限 二进制值
查看 001(1)
新增 010(2)
修改 100(4)

我们用 000 来表示初始权限(未拥有权限),这样赋予或删除权限的时候只修改了对应位置为1或0,不同权限所处的位置不同,不会互相冲突。

判断权限的时候通过 & 进行

按位与处理两个长度相同的二进制数,两个相应的二进位都为1,该位的结果值才为1,否则为0。

故通过 (authority & b) == b 可以判断是否拥有权限 b 。

BTW,linux 系统也是通过这种方式来进行权限判断的,对于文件的权限的 read/write/execute 分别用4/2/1表示。

灵活性

本方案通过数字来表示权限,故若有新权限加入的时候,只需在文档或注释里标明对应的数值即可,之前的代码或者数据无需修改。

例如上面的例子中,如果要添加一个新的权限-删除,只需设定删除对应的权限为8即可。

可使用的数值列为:
1 2 4 8 16 .... (每一个后续的值为前一个值*2)

拓展

本方案不仅只适用于权限判断,也可以用于叠加状态的判断

例如某条数据需要经过操作A和操作B才能进入下一步,而操作A、B互相独立,无操作顺序要求。

具体如何使用大家可以思考一下。

Enjoy it !

如果觉得文章对你有用,可以赞助我喝杯咖啡~

版权声明

转载请注明作者和文章出处
作者: 小鱼儿
首发于 https://blog.ricoo.top/8421fa-ze/

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

推荐阅读更多精彩内容