日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程语言 > php >内容正文

php

php 二进制权限,基于二进制位的权限控制(数据库里的二进制)

發布時間:2024/7/19 php 32 豆豆
生活随笔 收集整理的這篇文章主要介紹了 php 二进制权限,基于二进制位的权限控制(数据库里的二进制) 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

declare @a BINARY(2)

set @a ?= 32768

select @a

BINARY 字節 ?1B = 8位 bit

BINARY(2) = 16 位二進制數

換算16進制位4位

2進制數

最大值為524287 轉換16進制OxFFFF (111111111111111)

最高位值32768,轉換16進制Ox8000 即兩個字節位(1000000000000000)

如需16位二進制數據,只需聲明BINARY(2) 即可。

使用時在代碼中轉換。

****************

1.一種實用的權限控制算法

這里我介紹一種很常用,也比較Professor的權限控制思路。

這里我用java語言描述,其實都差不多的。自己轉一下就可以了。

為了方便,我們這里定義a^b為:a的b次方

這里,我們為每一個操作設定一個唯一的整數值,比如:

刪除A---0

修改A---1

添加A---2

刪除B---3

修改B---4

添加B---5

。。。

理論上可以有N個操作

這取決于你用于儲存用戶權限值的數據類型了。

這樣,如果用戶有權限:添加A---2;刪除B---3;修改B---4

那用戶的權限值?purview =2^2+2^3+2^4=28,也就是2的權的和了(之前打錯了)。

化成二進制可以表示為11100

這樣,如果要驗證用戶是否有刪除B的權限,就可以通過位與運算來實現。

在Java里,位與運算運算符號為&

即是:int value = purview &((int)Math.pow(2,3));

你會發現,當用戶有操作權限時,運算出來的結果都會等于這個操作需要的權限值!

原理:

位與運算,顧名思義就是對位進行與運算:

以上面的式子為例:purview & 2^3?也就是 28&8

將它們化成二進制有

11100

&??01000

-------------------

01000? ? ==? ?8(十進制) == 2^3

同理,如果要驗證是否有刪除A---0的權限

可以用:purview &((int)Math.pow(2,0));

即:

11100

&? ???00001

------------------------

00000? ?==??0(十進制)  != 2^0

這種算法的一個優點是速度快。可以同時處理N個權限

如果想驗證是否同時有刪除A---0和刪除B---3的權限

可以用purview&(2^0+2^3)==(2^0+2^3)?true:false;

設置多角色用戶。根據權限值判斷用戶的角色。。。

下面提供一個java的單操作權限判斷的代碼:

//userPurview是用戶具有的總權限

//optPurview是一個操作要求的權限為一個整數(沒有經過權的!)

public static boolean checkPower(int userPurview, int optPurview)

{

int purviewValue = (int)Math.pow(2, optPurview);

return (userPurview & purviewValue) == purviewValue;

}

當然,多權限的驗證只要擴展一下就可以了。

幾點注意事項:首先,一個系統可能有很多的操作,因此,請建立數據字典,以便查閱,修改時使用。其次,如果用數據庫儲存用戶權限,請注意數值的有效范圍。操作權限值請用唯一的整數!

如有疑問,請提出!天寒地凍,本人最怕人潑冷水了,知道這里高手如云。不要取笑,謝謝!

之后,有空我會將我的一些開發經驗在本帖中提出,和大家一起分享,研究一下。請大家支持

public?class?Test {

//?將字符串轉換成二進制字符串,以空格相隔

public?String toBinary(String str) {

char[] strChar = str.toCharArray();

String result =?"";

for?(int?i = 0; i < strChar.length; i++) {

result += Integer.toBinaryString(strChar[i]) +?" ";

}

return?result;

}

//?將二進制字符串轉換成Unicode字符串

public?String toStr(String binStr) {

String[] tempStr = StrToStrArray(binStr);

char[] tempChar =?new?char[tempStr.length];

for?(int?i = 0; i < tempStr.length; i++) {

tempChar[i] = toChar(tempStr[i]);

}

return?String.valueOf(tempChar);

}

//?將二進制字符串轉換為char

private?char?toChar(String binStr) {

int[] temp = binStrToIntArray(binStr);

int?sum = 0;

for?(int?i = 0; i < temp.length; i++) {

sum += temp[temp.length?- 1 - i] << i;

}

return?(char) sum;

}

//?將初始二進制字符串轉換成字符串數組,以空格相隔

private?String[] StrToStrArray(String str) {

return?str.split(" ");

}

//?將二進制字符串轉換成int數組

private?int[] binStrToIntArray(String binStr) {

char[] temp = binStr.toCharArray();

int[] result =?new?int[temp.length];

for?(int?i = 0; i < temp.length; i++) {

result[i] = temp[i] - 48;

}

return?result;

}

public?static?void?main(String[] args) {

Test cTob =?new?Test();

System.out.println(cTob.toBinary("橘子,好吃!aaa"));

System.out.println();

System.out.println(cTob.toBinary("999111"));

System.out.println();

System.out.println(cTob.toBinary("What a nice day!"));

System.out.println();

System.out.println(cTob.toBinary("^@^ - -!?()★"));

System.out.println();

System.out.println();

System.out.println(cTob.toStr("110101001011000 101101101010000 "

+?"1111111100001100 101100101111101 "

+?"101010000000011 1111111100000001 "

+?"1100001 1100001 1100001 "));

System.out.println(cTob.toStr("111001 111001 111001 "

+?"110001 110001 110001"));

System.out.println(cTob.toStr("1010111 1101000 1100001 "

+?"1110100 100000 1100001 100000 1101110 "

+?"1101001 1100011 1100101 100000 1100100 "

+?"1100001 1111001 100001 "));

System.out.println(cTob.toStr("1011110 1000000 1011110 "

+?"100000 101101 100000 101101 100001 100000 "

+?"1111111100001000 1111111100001001 10011000000101 "));

}

}

總結

以上是生活随笔為你收集整理的php 二进制权限,基于二进制位的权限控制(数据库里的二进制)的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。