欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

PHP生成隨機(jī)字符串(3種方法)

 更新時間:2015年09月25日 15:24:13   投稿:lijiao  
使用PHP開發(fā)應(yīng)用程序,尤其是網(wǎng)站程序,常常需要生成隨機(jī)密碼,而本文收集整理了幾種生成隨機(jī)字符串的方法,希望對您有所幫助。

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

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

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

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

該算法主要用到了兩個函數(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)的字符。

function create_password($pw_length =  
{ 
$randpwd = ”; 
for ($i = 0; $i < $pw_length; $i++) 
{ 
$randpwd .= chr(mt_rand(33, 126)); 
} 
return $randpwd; 
} 
// 調(diào)用該函數(shù),傳遞長度參數(shù)$pw_length = 6 
echo create_password(6); 

方法二

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

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

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

function generate_password( $length = 8 ) { 
// 密碼字符集,可任意添加你需要的字符 
$chars = ‘a(chǎn)bcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789!@#$%^&*()-_ []{}<>~`+=,.;:/?|'; 
$password = ”; 
for ( $i = 0; $i < $length; $i++ ) 
{ 
// 這里提供兩種字符獲取方式 
// 第一種是使用 substr 截取$chars中的任意一位字符; 
// 第二種是取字符數(shù)組 $chars 的任意元素 
// $password .= substr($chars, mt_rand(0, strlen($chars) – 1), 1); 
$password .= $chars[ mt_rand(0, strlen($chars) - 1) ]; 
} 
return $password; 
} 

方法三

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

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

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

function make_password( $length = 8 ) 
{ 
 
// 密碼字符集,可任意添加你需要的字符 
$chars = array(‘a(chǎn)', ‘b', ‘c', ‘d', ‘e', ‘f', ‘g', ‘h', 
‘i', ‘j', ‘k', ‘l','m', ‘n', ‘o', ‘p', ‘q', ‘r', 's', 
‘t', ‘u', ‘v', ‘w', ‘x', ‘y','z', ‘A', ‘B', ‘C', ‘D', 
‘E', ‘F', ‘G', ‘H', ‘I', ‘J', ‘K', ‘L','M', ‘N', ‘O', 
‘P', ‘Q', ‘R', ‘S', ‘T', ‘U', ‘V', ‘W', ‘X', ‘Y','Z', 
‘0′, ‘1′, ‘2′, ‘3′, ‘4′, ‘5′, ‘6′, ‘7′, ‘8′, ‘9′, ‘!', 
‘@','#', ‘$', ‘%', ‘^', ‘&', ‘*', ‘(‘, ‘)', ‘-', ‘_', 
‘[', ']‘, ‘{‘, ‘}', ‘<', ‘>', ‘~', ‘`', ‘+', ‘=', ‘,', 
‘.', ‘;', ‘:', ‘/', ‘?', ‘|'); 
 
// 在 $chars 中隨機(jī)取 $length 個數(shù)組元素鍵名 
$keys = ($chars, $length); 
$password = ”; 
for($i = 0; $i < $length; $i++) 
{ 
// 將 $length 個數(shù)組元素連接成字符串 
$password .= $chars[$keys[$i]]; 
} 
return $password; 
} 

時間效率對比

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

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

相關(guān)文章

最新評論