国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > PHP > 正文

【PHP】淺談生成隨機密碼的方法

2019-11-10 19:01:43
字體:
來源:轉載
供稿:網友

使用php開發應用程序,尤其是網站程序,常常需要生成隨機密碼,如用戶注冊生成隨機密碼,用戶重置密碼也需要生成一個隨機的密碼。隨機密碼也就是一串固定長度的字符串,這里我收集整理了幾種生成隨機字符串的方法,以供大家參考。

方法一

在 33 – 126 中生成一個隨機整數,如 35,將 35 轉換成對應的ASCII碼字符,如 35 對應 #重復以上 1、2 步驟 n 次,連接成 n 位的密碼

說明:

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

<?phpfunction create_passWord($pw_length = 8) { $randpwd = ''; for ($i = 0; $i < $pw_length; $i++) { $randpwd .= chr(mt_rand(33, 126)); } return $randpwd;}// 調用該函數,傳遞長度參數$pw_length = 6echo create_password(6);

方法二

預置一個的字符串 $chars ,包括 a – z,A – Z,0 – 9,以及一些特殊字符在 $chars 字符串中隨機取一個字符重復第二步 n 次,可得長度為 n 的密碼<?phpfunction generate_password( $length = 8 ) { // 密碼字符集,可任意添加你需要的字符 $chars = 'abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789!@#$%^&*()-_[]{}<>~`+=,.;:/?|'; $password = ''; for ( $i = 0; $i < $length; $i++ ) { // 這里提供兩種字符獲取方式 // 第一種是使用 substr 截取$chars中的任意一位字符; // 第二種是取字符數組 $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()從數組 $chars 中隨機選出 $length 個元素根據已獲取的鍵名數組 $keys,從數組 $chars 取出字符拼接字符串。該方法的缺點是相同的字符不會重復取。<?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 中隨機取 $length 個數組元素鍵名 $keys = array_rand($chars, $length); $password = ''; for($i = 0; $i < $length; $i++) { // 將 $length 個數組元素連接成字符串 $password .= $chars[$keys[$i]]; } return $password;}echo make_password(6);

方法四

利用md5加密當前時間戳的方式,截取部分幾位。生成的密碼只包括字母和數字。

time() 獲取當前的 Unix 時間戳將第一步獲取的時間戳進行 md5() 加密將第二步加密的結果,截取 n 位即得想要的密碼<?phpfunction get_password( $length = 8 ) { $str = substr(md5(time()), 0, $length); return $str;}echo get_password(6);

方法五

str_shuffle — 隨機打亂一個字符串

<?phpfunction random_pass( $length = 8 ){ $password = ''; $chars = 'abcdefghijkmnpqrstuvwxyz23456789ABCDEFGHIJKMNPQRSTUVWXYZ'; //去掉1跟字母l防混淆 if ($length > strlen($chars)) {//位數過長重復字符串一定次數 $chars = str_repeat($chars, ceil($length / strlen($chars))); } $chars = str_shuffle($chars); $password = substr($chars, 0, $length); return $password;}echo random_pass(6);
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 长泰县| 贡觉县| 田阳县| 浠水县| 天峻县| 柯坪县| 长阳| 金沙县| 惠来县| 姜堰市| 西吉县| 梨树县| 清原| 五大连池市| 贵阳市| 民和| 长泰县| 丹寨县| 岳普湖县| 霍山县| 灵宝市| 郎溪县| 长白| 大冶市| 巴彦淖尔市| 陆良县| 雷山县| 崇明县| 湟源县| 博白县| 绥化市| 巫山县| 南和县| 张家界市| 玉环县| 台山市| 内江市| 郯城县| 灵川县| 洪湖市| 芜湖县|