用户名:
密 码: 记住
您当前的位置:首页 > 网络编程 > php教程

php生成随机密码实现函数总结

时间:2015-01-23  来源:西部数据  作者:西部数据

根据我的理解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
来顶一下
返回首页
返回首页
推荐资讯
WiFi太不安全:7岁女孩11分钟内入侵公共网络 WiFi太不安全:7岁女孩11分钟内入侵近期刚刚发布研究说WiFi网络能获得人们手机里多少私人信息,
不服跑个分?人工智能也出现“刷分”乱象 不服跑个分?人工智能也出现“刷分2014年,人工智能领域突然爆发,成为了科研和科技创业的热门
相关文章
    无相关信息
栏目更新
栏目热门