0

0

基于原生PHP交叉会员权限控制_PHP教程

php中文网

php中文网

发布时间:2016-07-13 10:21:02

|

1454人浏览过

|

来源于php中文网

原创

Pix2Pix
Pix2Pix

使用Prompt编辑视频

下载

基于原生PHP交叉会员权限控制

对于一个网站的后台管理系统,单一的超级管理员权限往往不能满足我们的需求,尤其是对于大型网站而言,这种单一的权限会引发许许多多的问题出现。

 
比如:一个网站编辑,平时他只是负责公司网站的公告更新,但如果网站后台没有严格的权限限制,他是不是就可以操作到客户的一些信息,这是存在很大隐患的。
 
如果学过ThinkPHP框架的朋友一定知道有个东西叫RBAC,今天咱不说那个,来说说在原生PHP语言中,怎么实现交叉权限控制。
 
好了,话不多说,老样子,直接说原理,上代码。
 
 
 
 
 
对于权限的交叉控制可以有很多种方法实现,这里只是提供一种思路:(我采用的是二进制数的方法)
 
一、这里先提下按位与和按位或的运算方法:
 
1、按位与运算符(&)
 
参加运算的两个数据,按二进制位进行“与”运算。(“与”运算=>是否有包含的值如:7&8=0)
 
 
 
运算规则:0&0=0;   0&1=0;    1&0=0;     1&1=1;
 
       即:两位同时为“1”,结果才为“1”,否则为0
 
例如:3&5  即 0000 0011 & 0000 0101 = 0000 0001   因此,3&5的值得1。
 
 
 
另,负数按补码形式参加按位与运算。
 
 
 
 
 
2、按位或运算符(|)
 
 
 
参加运算的两个对象,按二进制位进行“或”运算。(“或”运算=>能包含的值如:7=4|2|1,用“异或”去除包含如:7^2)
 
 
 
运算规则:0|0=0;   0|1=1;   1|0=1;    1|1=1;
 
 
 
      即 :参加运算的两个对象只要有一个为1,其值为1。
 
 
 
例如:3|5 即 0000 0011 | 0000 0101 = 0000 0111   因此,3|5的值得7。 
 
 
 
 
 
 
 
另,负数按补码形式参加按位或运算。
 
 
 
了解了按位与和按位或的运算,我们来看下面这个例子:
 
复制代码
 1
 2     define('ADD',1);//二进制1
 3     define('DELETE',2);//二进制10
 4     define('UPDATE',4);//二进制100
 5     define('SELECT',8);//二进制1000
 6 
 7     //有权限为1,没有权限为0
 8     $admin=ADD|DELETE|UPDATE|SELECT;//1111
 9     $editor=ADD|UPDATE|SELECT;//1101
10     $user=SELECT;//1000
11 ?>
复制代码
我把增删改查分别做成了4个权限并定为常量
 
1的二进制数是1,2的二进制数是10,4的二进制数是100,8的二进制数是1000,这里刚好成一个规律
 
可能有些朋友会问上面权限变量admin,editor,user所对应的1111,1101,1000是怎么来的?
 
PHP里有一个十进制数转二进制数的函数叫decbin()
 
下面是对应的函数解释:
 
复制代码
decbin
(PHP 3, PHP 4, PHP 5)
 
decbin -- 十进制转换为二进制
说明
string decbin ( int number )
 
 
返回一字符串,包含有给定 number 参数的二进制表示。所能转换的最大数值为十进制的 4294967295,其结果为 32 个 1 的字符串。 
 
例子 1. decbin() 范例
echo decbin(12) . "\n";
echo decbin(26);
?>  
 
上例将输出:
1100
11010
参见 bindec(),decoct(),dechex() 和 base_convert()。 
复制代码
我们来测试输出看看吧:
 
复制代码
 1
 2     
 3     
 4     define('ADD',1);//二进制1
 5     define('DELETE',2);//二进制10
 6     define('UPDATE',4);//二进制100
 7     define('SELECT',8);//二进制1000
 8 
 9     //有权限为1,没有权限为0
10     $admin=ADD|DELETE|UPDATE|SELECT;//1111 15
11     $editor=ADD|UPDATE|SELECT;//1101 13
12     $user=SELECT;//1000 8
13 
14     echo decbin($admin)."
";
15     echo decbin($editor)."
";
16     echo decbin($user)."
";
17 
18 
19 ?>
复制代码
输出结果:
 
 
 
 那么我们就可以运用这个运算来判断权限了,1代表有权限,0代表无权限
 
比如:
 
admin(超级管理员)拥有的权限是增删改查也就是1111——>0000 1111
 
editor(网站编辑)拥有的权限是增,改,查也就是1101——>0000 1101
 
user(普通用户)只拥有浏览、查询的权限也就是1000——>0000 1000
 
那么我们只要对它们进行按位与运算就可以判断是否具备权限了
 
例如:(从后往前看)  取十进制(数据库存储类型值)转二进制进行"与"运算 
 
网站编辑权限 0000 1101(权限十进制为13) & 0000 0010(删除权限十进制为2转二进制为10)  结果:0000 0000 也就是没有具备权限
 
再来试试
 
普通用户权限 0000 1000 & 0000 0001(添加权限十进制为1二进制为1)  结果:0000 0000 也一样不具备权限
 
超级管理员权限0000 1111 & 0000 1101(网站编辑的权限)  结果:0000 1101 也就是具备了网站编辑的权限
 
 
 
好了看具体实例吧
 
 
 
我建了一个数据库,里面有2张表
 
一张是user用户表:
 
 
 
gid代表权限表的组id
 
 
 
 
 
一张是权限表:
 
 
 
flag代表增删改查的权限,可根据自己需要定义
 
 
 
 
 
基本配置页面:config.php
 
复制代码
 1
 2     
 3     define('HOST','localhost');
 4     define('DBNAME','member');
 5     define('USER', 'root');
 6     define('PASS', '');
 7 
 8 
 9     $link=@mysql_connect(HOST,USER,PASS) or die('数据库连接失败');
10 
11     mysql_select_db(DBNAME,$link);
12 
13     define('ADD',1);//二进制1
14     define('DELETE',2);//二进制10
15     define('UPDATE',4);//二进制100
16     define('SELECT',8);//二进制1000
17 
18     //有权限为1,没有权限为0
19     $admin=ADD|DELETE|UPDATE|SELECT;//1111
20     $editor=ADD|UPDATE|SELECT;//1101
21     $user=SELECT;//1000
22 ?>
复制代码
 
 
登陆首页:index.html
 
复制代码
 1
 2
 3
 4    
 5     Document
 6
 7
 8    
 9         账号:
10         密码:
11            
12        
13
14
复制代码
提交页面:action.php
 
复制代码
 1
 2     
 3     require_once('config.php');
 4     $username=$_POST['username'];
 5     $password=$_POST['password'];
 6 
 7 
 8     $sql="select * from user as a,role as b where a.gid=b.gid 
 9     and a.username='$username' and password='$password'";
10 
11     $result=mysql_query($sql);
12     if($data=mysql_fetch_array($result)){
13         //账号验证通过,判断对应权限
14         //此处判断的是 是否具备删除权限 如:user数据库存储的值为8转二进制为1000 删除权限的值为2转二进制为0010 与运算0000 无权限
15         if($data['flag']&DELETE){
16             echo "你有删除权限";
17         }else{
18             echo "你没有删除权限";
19         }
20 
21     }else{
22         echo "错误账号密码";
23     }
24     
25 
26 ?>

www.bkjia.comtruehttp://www.bkjia.com/PHPjc/862109.htmlTechArticle基于原生PHP交叉会员权限控制 对于一个网站的后台管理系统,单一的超级管理员权限往往不能满足我们的需求,尤其是对于大型网站而言,...

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
pixiv网页版官网登录与阅读指南_pixiv官网直达入口与在线访问方法
pixiv网页版官网登录与阅读指南_pixiv官网直达入口与在线访问方法

本专题系统整理pixiv网页版官网入口及登录访问方式,涵盖官网登录页面直达路径、在线阅读入口及快速进入方法说明,帮助用户高效找到pixiv官方网站,实现便捷、安全的网页端浏览与账号登录体验。

928

2026.02.13

微博网页版主页入口与登录指南_官方网页端快速访问方法
微博网页版主页入口与登录指南_官方网页端快速访问方法

本专题系统整理微博网页版官方入口及网页端登录方式,涵盖首页直达地址、账号登录流程与常见访问问题说明,帮助用户快速找到微博官网主页,实现便捷、安全的网页端登录与内容浏览体验。

307

2026.02.13

Flutter跨平台开发与状态管理实战
Flutter跨平台开发与状态管理实战

本专题围绕Flutter框架展开,系统讲解跨平台UI构建原理与状态管理方案。内容涵盖Widget生命周期、路由管理、Provider与Bloc状态管理模式、网络请求封装及性能优化技巧。通过实战项目演示,帮助开发者构建流畅、可维护的跨平台移动应用。

183

2026.02.13

TypeScript工程化开发与Vite构建优化实践
TypeScript工程化开发与Vite构建优化实践

本专题面向前端开发者,深入讲解 TypeScript 类型系统与大型项目结构设计方法,并结合 Vite 构建工具优化前端工程化流程。内容包括模块化设计、类型声明管理、代码分割、热更新原理以及构建性能调优。通过完整项目示例,帮助开发者提升代码可维护性与开发效率。

29

2026.02.13

Redis高可用架构与分布式缓存实战
Redis高可用架构与分布式缓存实战

本专题围绕 Redis 在高并发系统中的应用展开,系统讲解主从复制、哨兵机制、Cluster 集群模式及数据分片原理。内容涵盖缓存穿透与雪崩解决方案、分布式锁实现、热点数据优化及持久化策略。通过真实业务场景演示,帮助开发者构建高可用、可扩展的分布式缓存系统。

103

2026.02.13

c语言 数据类型
c语言 数据类型

本专题整合了c语言数据类型相关内容,阅读专题下面的文章了解更多详细内容。

54

2026.02.12

雨课堂网页版登录入口与使用指南_官方在线教学平台访问方法
雨课堂网页版登录入口与使用指南_官方在线教学平台访问方法

本专题系统整理雨课堂网页版官方入口及在线登录方式,涵盖账号登录流程、官方直连入口及平台访问方法说明,帮助师生用户快速进入雨课堂在线教学平台,实现便捷、高效的课程学习与教学管理体验。

17

2026.02.12

豆包AI网页版入口与智能创作指南_官方在线写作与图片生成使用方法
豆包AI网页版入口与智能创作指南_官方在线写作与图片生成使用方法

本专题汇总豆包AI官方网页版入口及在线使用方式,涵盖智能写作工具、图片生成体验入口和官网登录方法,帮助用户快速直达豆包AI平台,高效完成文本创作与AI生图任务,实现便捷智能创作体验。

764

2026.02.12

PostgreSQL性能优化与索引调优实战
PostgreSQL性能优化与索引调优实战

本专题面向后端开发与数据库工程师,深入讲解 PostgreSQL 查询优化原理与索引机制。内容包括执行计划分析、常见索引类型对比、慢查询优化策略、事务隔离级别以及高并发场景下的性能调优技巧。通过实战案例解析,帮助开发者提升数据库响应速度与系统稳定性。

92

2026.02.12

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
Laravel---API接口
Laravel---API接口

共7课时 | 0.6万人学习

ThinkPHP6.x API接口--十天技能课堂
ThinkPHP6.x API接口--十天技能课堂

共14课时 | 1.2万人学习

ThinkPHP配置开发与CMS后台实战
ThinkPHP配置开发与CMS后台实战

共87课时 | 9.1万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号