使用php開發(fā)應(yīng)用程序,尤其是網(wǎng)站程序,常常需要生成隨機(jī)密碼,如用戶注冊生成隨機(jī)密碼,用戶重置密碼也需要生成一個隨機(jī)的密碼。隨機(jī)密碼也就是一串固定長度的字符串,這里我收集整理了幾種生成隨機(jī)字符串的方法,以供大家參考。
說明:
該算法主要用到了兩個函數(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,65 —— 90 對應(yīng)A —— Z的英文字母,具體可參考ASCII 碼表。
$chars ,包括 a – z,A – Z,0 – 9,以及一些特殊字符在 $chars 字符串中隨機(jī)取一個字符重復(fù)第二步 n 次,可得長度為 n 的密碼<?phpfunction generate_password( $length = 8 ) { // 密碼字符集,可任意添加你需要的字符 $chars = 'abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789!@#$%^&*()-_[]{}<>~`+=,.;:/?|'; $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;}echo generate_password(6);$chars ,包括 a – z,A – Z,0 – 9,以及一些特殊字符通過array_rand()從數(shù)組 $chars 中隨機(jī)選出 $length 個元素根據(jù)已獲取的鍵名數(shù)組 $keys,從數(shù)組 $chars 取出字符拼接字符串。該方法的缺點(diǎn)是相同的字符不會重復(fù)取。<?phpfunction make_password( $length = 8 ) { // 密碼字符集,可任意添加你需要的字符 $chars = array('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', '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 = array_rand($chars, $length); $password = ''; for($i = 0; $i < $length; $i++) { // 將 $length 個數(shù)組元素連接成字符串 $password .= $chars[$keys[$i]]; } return $password;}echo make_password(6);利用md5加密當(dāng)前時間戳的方式,截取部分幾位。生成的密碼只包括字母和數(shù)字。
time() 獲取當(dāng)前的 Unix 時間戳將第一步獲取的時間戳進(jìn)行 md5() 加密將第二步加密的結(jié)果,截取 n 位即得想要的密碼<?phpfunction get_password( $length = 8 ) { $str = substr(md5(time()), 0, $length); return $str;}echo get_password(6);str_shuffle — 隨機(jī)打亂一個字符串
<?phpfunction random_pass( $length = 8 ){ $password = ''; $chars = 'abcdefghijkmnpqrstuvwxyz23456789ABCDEFGHIJKMNPQRSTUVWXYZ'; //去掉1跟字母l防混淆 if ($length > strlen($chars)) {//位數(shù)過長重復(fù)字符串一定次數(shù) $chars = str_repeat($chars, ceil($length / strlen($chars))); } $chars = str_shuffle($chars); $password = substr($chars, 0, $length); return $password;}echo random_pass(6);新聞熱點(diǎn)
疑難解答