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

首頁 > 語言 > PHP > 正文

php生成隨機密碼實現函數總結

2024-09-04 11:48:32
字體:
來源:轉載
供稿:網友

根據我的理解php生成隨機密碼就是我們把一些要生成的字符預置一個的字符串包括數字拼音之類的以及一些特殊字符,這樣我們再隨機取字符組成我們想要的隨機密碼了.

下面總結了一些實例各位朋友可參考.

例1,最簡潔的生成方法,代碼如下:

  1. function generatePassword($length=8) 
  2.     $chars = array_merge(range(0,9), 
  3.                      range('a','z'), 
  4.                      range('A','Z'), 
  5.                      array('!','@','$','%','^','&','*')); 
  6.     shuffle($chars); 
  7.     $password = ''
  8.     for($i=0; $i<8; $i++) { 
  9.         $password .= $chars[$i]; 
  10.     } 
  11.     return $password

例2:

1、在 33 – 126 中生成一個隨機整數,如 35,

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

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

代碼如下:

  1. function create_password($pw_length = 8) 
  2.     $randpwd = ''
  3.     for ($i = 0; $i < $pw_length$i++)  
  4.     { 
  5.         $randpwd .= chr(mt_rand(33, 126)); 
  6.     } 
  7.     return $randpwd
  8.  
  9. // 調用該函數,傳遞長度參數$pw_length = 6 
  10. echo create_password(6); 

實例代碼如下:

  1. <?php  
  2. mt_srand((double) microtime() * 1000000);  
  3.    
  4. function gen_random_password($password_length = 32, $generated_password = ""){  
  5.  $valid_characters = "abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789";  
  6.  $chars_length = strlen($valid_characters) - 1;  
  7.  for($i = $password_length$i--; ) {  
  8.   //$generated_password .= $valid_characters[mt_rand(0, $chars_length)];  
  9.    
  10.   $generated_password .= substr($valid_characters, (mt_rand()%(strlen($valid_characters))), 1);  
  11.  }  
  12.  return $generated_password;  
  13. }  
  14.    
  15. ?><!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">  
  16. <html>  
  17. <head>  
  18. <title>php 密碼生成器 v 4.0</title>  
  19. <style type="text/css">  
  20. body {  
  21.  font-family: Arial;  
  22.  font-size: 10pt;  
  23. }  
  24. </style>  
  25. </head>  
  26. <body>  
  27. <span style="font-weight: bold; font-size: 15pt;">密碼生成器v4.0 by freemouse</span><br /><br />  
  28. <?php  
  29.    
  30. if (isset($_GET['password_length'])){  
  31.  if(preg_match("/([0-9]{1,8})/"$_GET['password_length'])){  
  32.   print("密碼生成成功:<br />  
  33. <span style="font-weight: bold">" . gen_random_password($_GET['password_length']) . "</span><br /><br />n");  
  34.  } else {  
  35.   print("密碼長度不正確!<br /><br />n");  
  36.  }  
  37. }  
  38.    
  39. print <<< end 
  40. 請為密碼生成其指定生成密碼的長度:<br /><br />  
  41. <form action="{$_SERVER['PHP_SELF']}" method="get">  
  42.  <input type="text" name="password_length">  
  43.  <input type="submit" value="生成">  
  44. </form>  
  45. end;  
  46.    
  47. ?>  
  48. </body>  
  49. </html> 

例4

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

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

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

代碼如下:

  1. function generate_password( $length = 8 ) { 
  2.     // 密碼字符集,可任意添加你需要的字符 
  3.     $chars = 'abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789!@#$%^&*()-_ []{}<>~`+=,.;:/?|'
  4.  
  5.     $password = ''
  6.     for ( $i = 0; $i < $length$i++ )  
  7.     { 
  8.         // 這里提供兩種字符獲取方式 
  9.         // 第一種是使用 substr 截取$chars中的任意一位字符; 
  10.         // 第二種是取字符數組 $chars 的任意元素 
  11.         // $password .= substr($chars, mt_rand(0, strlen($chars) - 1), 1); 
  12.         $password .= $chars[ mt_rand(0, strlen($chars) - 1) ]; 
  13.     } 
  14.  
  15.     return $password

上面經過測試性能都不如下面這個

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

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

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

代碼如下:

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

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 丹寨县| 神池县| 诸暨市| 故城县| 太湖县| 福建省| 陆川县| 城步| 芜湖县| 视频| 肃宁县| 曲松县| 沈阳市| 孝义市| 拜城县| 迭部县| 滕州市| 吐鲁番市| 亚东县| 长宁县| 南郑县| 吕梁市| 礼泉县| 麦盖提县| 青阳县| 台中县| 雷州市| 涿州市| 鹤岗市| 双城市| 睢宁县| 滦平县| 平阴县| 灌云县| 云浮市| 渭南市| 阜平县| 桃园市| 左贡县| 尼玛县| 霍州市|