パーミッションコードは32ビットのint型でバイナリで制御します。例えば、パーミッションコードの合計が1000の場合、4桁目はパーミッションがあり、それ以外はパーミッションが無いことを意味します。 ?

WBOY
リリース: 2016-06-23 13:42:13
オリジナル
968 人が閲覧しました

バイナリは、どのビットに権限があるかを示すために 32 ビットの int 型を使用します。 次の 32 ビット バイナリは、権限コードを示します。
すべてに権限がある場合: 11111111 11111111 11111111 11111111 // (以下の最初の 00000 は省略できます)
最小値のみ。 1 人目の許可: 00000000 00000000 00000000 00000001
1 人目の許可: 00000000 00000000 00000000 00000010
2 人目の許可: 00000000 0000 0000 00000 00000100
複数の権限: 00000000 00000000 0000000000000101 2人が権限を持っています)
私が欲しいもの質問したいのは、私の 0 番目の位置がアクセス許可の追加である場合、1 番目はアクセス許可の検索、2 番目はアクセス許可の更新、そして 3 番目はアクセス許可の削除です。
しかし、この人のアクセス許可が 1 つしかない場合、どうやって判断すればよいでしょうか?権限があるか、または指定された権限コードに複数の権限が含まれているかを判断するにはどうすればよいですか?
誰がメソッドを記述して、取得した許可コードをメソッドに入れて判断できるか見てみましょう?
実際、私が判断しなければならないのは、それをフロントエンドに配置し、フロントエンド インターフェイスに 4 つのチェック ボックスを表示することです。
追加 削除 変更 削除 // バックエンドが 2 つの権限があると判断した場合、ユーザーはインターフェイスに入るときに 2 つのチェック ボックスが表示されますが、このボックスは直接選択されていますか? ? ? ?ここで、PHP でのアクセス許可の設定の問題が発生します。アドバイスをいただけますか。 ? ? 、? ? /、? ? ? ?


ディスカッションへの返信 (解決策)

Linux の制限メソッドを試してください 777 755 .... フロントエンド表示ルートには

分割と判定があり、これらの 2 つのステップになるはずです。 。 。

私が見た権限のほとんどは、1、1、1、1、1、1、1、1 で、区別しやすいように区切り文字が付いています。

どのように分割したかはわかりませんが、実行できる小さな具体例があれば、それを超えて拡張できると思います。 。 。 。 。 。 。 。 。 。 。

非常に単純です。ビットは

$权限 = array(  '增加' => 0b1,  '查找' => 0b10,  '更新' => 0b100,  '删除' => 0b1000,);$权限字 = 0b101;foreach($权限 as $k=>$v) {  printf("<input type=checkbox name=permit[] value=%s %s>%s<br>\n", $k, $权限字 & $v ? 'checked' : '', $k);}
ログイン後にコピー
<input type=checkbox name=permit[] value=增加 checked>增加<br><input type=checkbox name=permit[] value=查找 >查找<br><input type=checkbox name=permit[] value=更新 checked>更新<br><input type=checkbox name=permit[] value=删除 >删除<br>
ログイン後にコピー
と同じです

$权限 = array(  '增加' => 0b1,  '查找' => 0b10,  '更新' => 0b100,  '删除' => 0b1000,);$权限字 = 0b101;foreach($权限 as $k=>$v) {  printf("<input type=checkbox name=permit[] value=%s %s>%s<br>\n", $v, $权限字 & $v ? 'checked' : '', $k);}
ログイン後にコピー
<input type=checkbox name=permit[] value=1 checked>增加<br><input type=checkbox name=permit[] value=2 >查找<br><input type=checkbox name=permit[] value=4 checked>更新<br><input type=checkbox name=permit[] value=8 >删除<br>
ログイン後にコピー

複数の権限の問題を考慮すると、pow の 2 番目のパラメータは上向きに増加し続けることができます。理解できるかわかりません

$add=pow(2,1);//2$del=pow(2,2);//4$update=pow(2,3);//8$query=pow(2,4);//16//增加&删除$p=$add+$del;if(getstatus($p,1)){//1是查询	echo '有增加的权限<br>';}//增加&删除&修改$p=$add+$del+$update;if(getstatus($p,3)){//3是修改	echo '有修改的权限<br>';}if(!getstatus($p,4)){//4是查询	echo '没有查询的权限<br>';}function getstatus($status,$p){	$t = $status & pow(2, $p) ? 1 : 0;	return $t;}
ログイン後にコピー

5階の方法を試しました。フロントエンドのコードにはインポートされた形式があり、出力がフロントエンドに入力されると、常にその形式に変換されません。何が起こっているのかわかりません。printf() の前にコードを追加する必要がありますか?ブロック名="本文">
< ;/ブロック> ,,,,,,,,,,,,,,,,,,,,,,,,,, 、、、、、、、、、、、、、、
Web ページのソース コードを表示する場合、これら
Web ページのソース コードを表示する場合、追加


更新
削除
このブロックにありませんか? ?解決策

単一のフラグにこの権限があるかどうかを判断するために 32 種類の権限を設定できるはずです

getAuth($postStatus, $targetStatus){    return $status & $targetStatus;}getAuth(0x21f, 0x78);    //判断是否有 00000000 00000000 00000000 011111000权限
ログイン後にコピー


プログラムの観点から見ると、PHP でのこのアプローチは良いことよりも害があるようです。最適化効果; データ構造の観点からは、管理と検索が不便です
個人的な意見

ソース:php.cn
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート
私たちについて 免責事項 Sitemap
PHP中国語ウェブサイト:福祉オンライン PHP トレーニング,PHP 学習者の迅速な成長を支援します!