卖逼视频免费看片|狼人就干网中文字慕|成人av影院导航|人妻少妇精品无码专区二区妖婧|亚洲丝袜视频玖玖|一区二区免费中文|日本高清无码一区|国产91无码小说|国产黄片子视频91sese日韩|免费高清无码成人网站入口

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字符的隨機字符串?

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

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

2、將35轉換成對應的ASCII碼字符,如35對應#。

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

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

方法二

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

2、在 $chars 字符串中隨機取一個字符。

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

方法三

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

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

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

時間效率對比

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

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