目次
基于原生PHP交叉会员权限控制
ホームページ php教程 php手册 基于原生PHP交叉会员权限控制

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

Jun 13, 2016 am 09:27 AM
メンバー 権限

基于原生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 ?>

このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。

ホットAIツール

Undresser.AI Undress

Undresser.AI Undress

リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover

AI Clothes Remover

写真から衣服を削除するオンライン AI ツール。

Undress AI Tool

Undress AI Tool

脱衣画像を無料で

Clothoff.io

Clothoff.io

AI衣類リムーバー

AI Hentai Generator

AI Hentai Generator

AIヘンタイを無料で生成します。

ホットツール

メモ帳++7.3.1

メモ帳++7.3.1

使いやすく無料のコードエディター

SublimeText3 中国語版

SublimeText3 中国語版

中国語版、とても使いやすい

ゼンドスタジオ 13.0.1

ゼンドスタジオ 13.0.1

強力な PHP 統合開発環境

ドリームウィーバー CS6

ドリームウィーバー CS6

ビジュアル Web 開発ツール

SublimeText3 Mac版

SublimeText3 Mac版

神レベルのコード編集ソフト(SublimeText3)

WeChat読書メンバーシップを安く購入するにはどうすればよいですか? WeChat Reading でメンバーシップを購入する最良の方法を共有してください! WeChat読書メンバーシップを安く購入するにはどうすればよいですか? WeChat Reading でメンバーシップを購入する最良の方法を共有してください! Mar 16, 2024 am 08:22 AM

1. WeChat読書会員を安く購入するには? WeChat Reading でメンバーシップを購入する最良の方法を共有してください! 1. WeChat読書アプリを開き、読書福祉特別セッションに読書チャレンジがありますので、読書チャレンジに参加してください。 2. 参加料1元を支払い、7日間読書、継続時間7時間以上、図書コイン4枚付き4日分の有料会員カードを取得、年間約52週間参加可能、毎回参加すると、合計52元で合計208日、有料会員カード208図書コインを獲得できます。 3. 参加費3元、14日間読書、継続時間14時間以上、図書コイン10枚付き10日分の有料会員カードを取得、年間約26回参加可能、毎回参加すると費用がかかります合計78元、合計260日取得可能、有料会員カードは260図書コインです。 4. 4元を支払って参加し、21日間読むことができます。

ワンクリックで root 権限を有効にします (root 権限をすばやく取得します) ワンクリックで root 権限を有効にします (root 権限をすばやく取得します) Jun 02, 2024 pm 05:32 PM

ルート権限は、Android システムの管理者権限です。 root 権限を取得するには、通常、一連の面倒な手順が必要ですが、これは一般ユーザーにとってはあまり使いやすいものではないかもしれません。この記事では、ワンクリックで root 権限を有効にすることで、ユーザーがシステム権限を簡単に取得できるシンプルかつ効果的な方法を紹介します。 root 権限の重要性とリスクを理解し、root 権限を使用すると、ユーザーは携帯電話システムを完全に制御できるようになります。セキュリティ管理を強化し、テーマをカスタマイズし、ユーザーはプリインストールされたアプリケーションを削除できます。ただし、たとえば、システム ファイルを誤って削除してシステム クラッシュを引き起こしたり、root 権限を過剰に使用したり、マルウェアを誤ってインストールしたりすることも危険です。 root権限を使用する前に

QQミュージックのメンバーシップを無料で取得するにはどうすればよいですか? QQ Music メンバーシップを無料で取得するためのチュートリアル QQミュージックのメンバーシップを無料で取得するにはどうすればよいですか? QQ Music メンバーシップを無料で取得するためのチュートリアル Mar 13, 2024 pm 08:37 PM

QQ Music は多くのユーザーが使用する音楽視聴ソフトウェアです。一部の曲では、ダウンロードして再生する前にメンバーシップが必要です。では、QQ Music メンバーシップを無料で取得するにはどうすればよいですか?このサイトでは、QQ ミュージックのメンバーシップを無料で取得する方法に関するチュートリアルをユーザーに詳しく紹介します。 QQ Music メンバーシップを無料で取得するためのチュートリアル 1. まず、QQ Music を開きます。 2. 私のホームページにアクセスし、右上隅にある 3 本の水平線をクリックします。 3. ここをクリックして無料音楽リスニングモードを開きます。 4. ここには 15 秒間の広告が表示されますが、広告が終了するまで待つだけで 30 分間のメンバーシップ体験を得ることができます。体験時間は重ね合わせることができます。 5.読んだら会員登録してください。 QQ ミュージックを 1 日分受け取る

Kugou Music APP会員の自動更新と解約の手順 Kugou Music APP会員の自動更新と解約の手順 Mar 19, 2024 pm 07:28 PM

Kugou Music APP の会員自動更新をキャンセルするにはどうすればよいですか? Kugou Music の VIP 自動更新サービスを申し込んでいるユーザーがたくさんいますが、後でこのサービスをキャンセルしたいのですが、どこでキャンセルすればよいかわかりません。以下に、自動更新サービスをキャンセルする方法について説明します。 - Kugou Music をリニューアルしました 皆様のお役に立てれば幸いです。 Kugou Music APP で自動更新をキャンセルするのは非常に簡単です。メンバー センターに入り、音楽パッケージ/高級 VIP オプションを見つけて、自動更新を有効にするを選択し、クリックして更新を閉じるだけです。 2. WeChat: 下の図に示すように、支払いページに移動し、右上隅の 3 つの点をクリックして控除サービスを選択し、Kugou Music をクリックしてサービスを閉じます; 3. Alipay: 設定ページに移動し、支払い設定を選択し、パスワードなしの支払い/料金の自動引き落としを選択し、最後に Kugou Music を選択して契約を終了します。

Bilibiliメンバーシップを無料で取得するにはどうすればよいですか? Bステーションの大会員は無料 Bilibiliメンバーシップを無料で取得するにはどうすればよいですか? Bステーションの大会員は無料 Mar 15, 2024 pm 05:00 PM

Bilibili は、ダンスエリア、幽霊動物エリア、食べ物エリア、動物エリアなどを含む豊富なリソースを備えたビデオ再生プラットフォームです。しかし、現在では、サイト B でビデオを見るにはメンバーになる必要があることが多くなっています。お金をかけたくない場合は、サイト B のメンバーになることはできますか?ここでは編集者がBilibiliの無料会員になる方法を紹介しますので、お役に立てれば幸いです。 Bilibili で無料メンバーシップを取得する方法: Bilibili を開き、「マイ」をクリックします。 「クリエーションセンター」エリアの「クリエーションホーム」アイコンをクリックします。作成センターに入ったら、「タスクセンター」をクリックします。タスクセンターに入ったら、対応するタスクを読んで完了するとポイントを獲得できます。

知湖アプリ会員の自動更新のキャンセル方法 知湖アプリ会員の自動更新のキャンセル方法 知湖アプリ会員の自動更新のキャンセル方法 知湖アプリ会員の自動更新のキャンセル方法 Mar 13, 2024 am 11:04 AM

Zhihuアプリ会員の自動更新をキャンセルするにはどうすればよいですか? Zhihuアプリは非常に実用的なモバイルソフトウェアであり、このソフトウェアには多くの機能があり、各機能はユーザーに異なる感覚をもたらします。本ソフトウェアには、閲覧するために会員登録が必要なコンテンツがございます。このソフトウェアのメンバーシップは高価ではなく、継続的な月額メンバーシップの方が安くなります。自動更新の解除方法を知りたいプレイヤーもいると思いますので、自動更新の解除方法を以下にまとめましたので参考にしてください。 Zhihuアプリ会員の自動更新のキャンセル方法 Zhihu会員はApple Pay、WeChat Pay、Alipay Pay、Baidu Payの4つの更新方法を選択できます。 Baidu Pay を選択したユーザーは、WeChat または Alipay 支払いを通じて更新を管理できます。

QQスペースで権限アクセスを設定する方法 QQスペースで権限アクセスを設定する方法 Feb 23, 2024 pm 02:22 PM

QQ スペースで許可アクセスを設定するにはどうすればよいですか? QQ スペースで許可アクセスを設定できますが、ほとんどの友達は QQ スペースで許可アクセスを設定する方法を知りません。次は、QQ スペースで許可アクセスを設定する方法の図です。ユーザー向けのエディタです。テキストチュートリアルです。興味のある方はぜひ見に来てください。 QQ 使い方チュートリアル QQ スペース アクセス権限の設定方法 1. まず QQ アプリケーションを開き、メインページの左上隅にある [アバター] をクリックします; 2. 次に、左側の個人情報領域を展開し、[設定] 機能をクリックします左下隅にある; 3. 設定ページに移動します スワイプして [プライバシー] オプションを見つけます; 4. 次にプライバシー インターフェイスで、[アクセス許可設定] サービスを選択します; 5. 次に、最新のページに挑戦し、[スペース ダイナミクス] を選択します]; 6. QQスペースに再度セットアップします

Xianyuのメンバーになる方法_XianyuのVIPメンバーシップをアクティブ化する方法の紹介 Xianyuのメンバーになる方法_XianyuのVIPメンバーシップをアクティブ化する方法の紹介 Mar 20, 2024 pm 05:50 PM

Xianyu APPの「VIPメンバーシップ」機能は、ユーザーに提供される付加価値サービスです。 VIP メンバーになったユーザーは、製品露出の増加、展示機会の増加、独占的な顧客サービス、取引保証のアップグレードなど、ユーザーの売買体験と効率の向上に役立つ一連の特典や特典を享受できます。 Xianyu のメンバーになる方法 1. まず Xianyu ソフトウェアを開きます. ホームページに入った後、別のページに切り替えることができます. ここで右下隅の [My] をクリックします; 2. その後、For でさまざまなページを表示できます情報を確認するには、[My Fish Value] をクリックする必要があります; 3. 最後のクリック後、このページで VIP メンバーシップをアクティブ化できます。

See all articles