首页 > 语言 > 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

发表评论 共有条评论
用户名: 密码:
验证码: 匿名发表