国产成人毛片视频|星空传媒久草视频|欧美激情草久视频|久久久久女女|久操超碰在线播放|亚洲强奸一区二区|五月天丁香社区在线|色婷婷成人丁香网|午夜欧美6666|纯肉无码91视频

php數(shù)組拆分成字符串 php異或算法?

php異或算法?/*** PHP字符串“異或”算法* param array key* @param Request $request* @return mixed|string|void*/publ

php異或算法?

/**

* PHP字符串“異或”算法

* param array key

* @param Request $request

* @return mixed|string|void

*/

public function setSecretKey(Request $request){

$keyArr $request-input(key);

if(!is_array($keyArr) || empty($keyArr))

return;

foreach ($keyArr as $v){

if(empty($v) || (strlen($v) ! 32)){

return;

}

}

if(count($keyArr) 1)

return $keyArr[0];

$arrLength count($keyArr);

$initKey 00000000000000000000000000000000;

$initKeyArr str_split($initKey);

for($i 0;$i $arrLength;$i ){

$newKey ;

for($j 0;$j strlen($keyArr[$i]);$j ){

$str ;

$tmpArr str_split($keyArr[$i]);

$tmpA str_pad(base_convert($tmpArr[$j],16,2),4,0,STR_PAD_LEFT);

$tmpB str_pad(base_convert($initKeyArr[$j],16,2),4,0,STR_PAD_LEFT);

for($k0;$kstrlen($tmpA);$k ){

$str .(intval($tmpA[$k]) ^ intval($tmpB[$k]));

}

$tmpOneKey strtoupper(base_convert($str,2,16));

unset($str);

$newKey . $tmpOneKey;

}

unset($initKeyArr);

$initKeyArr str_split($newKey);

}

return join($initKeyArr);

}

請問怎樣用PHP生成長度為5字符的隨機(jī)字符串?

如用戶注冊生成隨機(jī)密碼,用戶重置密碼也需要生成一個(gè)隨機(jī)的密碼。隨機(jī)密碼也就是一串固定長度的字符串,文章整理了幾種生成隨機(jī)字符串的方法。方法一

1、在33 – 126中生成一個(gè)隨機(jī)整數(shù),如35。

2、將35轉(zhuǎn)換成對應(yīng)的ASCII碼字符,如35對應(yīng)#。

3、重復(fù)以上1、2步驟n次,連接成n位的密碼。

該算法主要用到了兩個(gè)函數(shù),mt_rand ( int $min , int $max )函數(shù)用于生成隨機(jī)整數(shù),其中 $min – $max 為 ASCII 碼的范圍,這里取 33 -126 ,可以根據(jù)需要調(diào)整范圍,如ASCII碼表中 97 – 122 位對應(yīng) a – z 的英文字母,具體可參考 ASCII碼表; chr ( int $ascii )函數(shù)用于將對應(yīng)整數(shù) $ascii 轉(zhuǎn)換成對應(yīng)的字符。

方法二

1、預(yù)置一個(gè)的字符串 $chars ,包括 a – z,A – Z,0 – 9,以及一些特殊字符。

2、在 $chars 字符串中隨機(jī)取一個(gè)字符。

3、重復(fù)第二步n次,可得長度為n的密碼。

方法三

1、預(yù)置一個(gè)的字符數(shù)組 $chars ,包括 a – z,A – Z,0 – 9,以及一些特殊字符。

2、通過array_rand()從數(shù)組$chars中隨機(jī)選出$length個(gè)元素。

3、根據(jù)已獲取的鍵名數(shù)組 $keys,從數(shù)組$chars取出字符拼接字符串。該方法的缺點(diǎn)是相同的字符不會重復(fù)取。

時(shí)間效率對比

我們使用以下PHP代碼,計(jì)算上面的3 個(gè)隨機(jī)密碼生成函數(shù)生成6 位密碼的運(yùn)行時(shí)間,進(jìn)而對他們的時(shí)間效率進(jìn)行一個(gè)簡單的對比。最終得出的結(jié)果是:

方法一:9.8943710327148E-5 秒 方法二:9.6797943115234E-5 秒 方法三:0.00017499923706055 秒 可以看出方法一和方法二的執(zhí)行時(shí)間都差不多,而方法三的運(yùn)行時(shí)間稍微長了點(diǎn)。通過比較三種方法的實(shí)現(xiàn)過程,時(shí)間效率對比,學(xué)習(xí)了PHP生成隨機(jī)字符串的三種方法,希望可以對大家今后的學(xué)習(xí)有所幫助。