使用二进制进行权限控制,可减少程序的逻辑判断以及提升效率,linux系统的777权限原理也是通过2进制进行判断的
例如,当需要判断某个账号是否有,增加,修改,删除,查询,常规判断需要4个权限字段,进行4种判断
使用二进制判断,只需要位运算判断权限码就行了
以下是原理以及教程
位运算说明:http://www.php20.cn/article/116
配置增删查改权限值
|
术语定义:
授权码:权限值的集合表示,例如linux的777权限,其实是
0001|0010|0100 = 0111(十进制7)
授权值:单个权限的权限值,例如linux的执行(1)写入2读取4,注意:权限值必须是2的幂级数,否则会出错!
授权:权限码=授权码的'或'操作0001|0010|0100 = 0111(十进制7)
回收权限:待回收的权限取反之后,和授权码进行'与'操作,例如,1111权限,去除增加权限,0001取反为1110,1110&1111 = 1110
验证权限:1:"授权值" = "授权码"&'授权值' 2:"授权码" = "授权码"|"授权值"
具体解释:
权限值:
php的int类型32位支持21亿左右的数值,转为二进制最大支持31位,可代表31种权限状态,理论上是足够用的啦
例如
|
授权:
例如用户a有查,改,删除权限
则
|
验证权限
判断用户$a是否有增加权限,
|
判断用户$a是否有修改权限
|
以上就是二进制权限控制的内容啦,这样进行验证权限,可以少去多重判断,少几个表字段,还能提高代码运行效率哦!