加入收藏 | 设为首页 | 会员中心 | 我要投稿 甘孜站长网 (https://www.0836zz.com.cn/)- 运维、物联设备、数据计算、智能推荐、云管理!
当前位置: 首页 > 站长学院 > PHP教程 > 正文

php随机密码生成的自定义函数

发布时间:2022-07-29 11:02:44 所属栏目:PHP教程 来源:互联网
导读:如果要做到安全密码与用户名都随机我有一个朋友做服务器的登录密码与用户名就是使用了phpmyadmin随机生成密码功能来做的,与其用phpmyadmin不如自己做了,下文整理了一些关于php随机密码生成的自定义函数供大家参考. 可以指定生成的字符串长度,代码如下: funct
  如果要做到安全密码与用户名都随机我有一个朋友做服务器的登录密码与用户名就是使用了phpmyadmin随机生成密码功能来做的,与其用phpmyadmin不如自己做了,下文整理了一些关于php随机密码生成的自定义函数供大家参考.
 
  可以指定生成的字符串长度,代码如下:
 
  function rand_str($length, $max=FALSE)
  {
    if (is_int($max) && $max > $length)
    {
      $length = mt_rand($length, $max);
    }
    $output = '';
      
    for ($i=0; $i<$length; $i++)
    {
      $which = mt_rand(0,2);
        
      if ($which === 0)
      {
        $output .= mt_rand(0,9);
      }
      elseif ($which === 1)
      {
        $output .= chr(mt_rand(65,90));
      }
      else
      {
        $output .= chr(mt_rand(97,122));
      }
    }
    return $output;
  }
  调用实例:$randstr = rand_str(16);
 
  生成随机字符串的函数,代码如下:
 
  <?php
  /**
  * 产生随机字符串
  *
  * 产生一个指定长度的随机字符串,并返回给用户
  *
  * @access public
  * @param int $len 产生字符串的位数
  * @return string
  */
  function randStr($len=6) {
  $chars='ABDEFGHJKLMNPQRSTVWXYabdefghijkmnpqrstvwxy23456789#%*'; // characters to build the password from
  mt_srand((double)microtime()*1000000*getmypid()); // seed the random number generater (must be done)
  $password='';//开源软件:phpfensi.com
  while(strlen($password)<$len)
  $password.=substr($chars,(mt_rand()%strlen($chars)),1);
  return $password;
  }
  ?>
  创建字符池.
 
  function randomkeys($length)
     {
         $pattern = '1234567890abcdefghijklmnopqrstuvwxyz
                     ABCDEFGHIJKLOMNOPQRSTUVWXYZ,./&l
                    t;>?;#:@~[]{}-_=+)(*&^%$?!';    //字符池
        for($i=0; $i<$length; $i++)
         {
             $key .= $pattern{mt_rand(0,35)};    //生成php随机数
         }
         return $key;
     }
     echo randomkeys(8);
  无需创建字符池
 
  function randomkeys($length)
     {
          $output='';
          for ($a = 0; $a < $length; $a++) {
              $output .= chr(mt_rand(35, 126));    //生成php随机数
          }
          return $output;
      }
      echo randomkeys(8);
  随机用户名和随机密码例子:
 
  //随机生成用户名(长度6-13)  
   
  function create_password($pw_length = 4){  
      $randpwd = '';  
      for ($i = 0; $i < $pw_length; $i++){  
          $randpwd .= chr(mt_rand(33, 126));  
      }  
      return $randpwd;  
  }
   
  function generate_username( $length = 6 ) {  
      // 密码字符集,可任意添加你需要的字符  
      $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;  
  }
  //调用
  $userId = 'user'.generate_username(6);  
  $pwd = create_password(9);
  mt_srand生成随机种子,密码的长度可以随意定义,最长32位.
 
  <?php
  mt_srand((double) microtime() * 1000000);
   
  function gen_random_password($password_length = 32, $generated_password = ""){
   $valid_characters = "abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789";
   $chars_length = strlen($valid_characters) - 1;
   for($i = $password_length; $i--; ) {
    //$generated_password .= $valid_characters[mt_rand(0, $chars_length)];
   
    $generated_password .= substr($valid_characters, (mt_rand()%(strlen($valid_characters))), 1);
   }
   return $generated_password;
  }
  ?>
  <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
  <html>
  <head>
  <title>php密码生成器</title>
  <style type="text/css">
  body {
   font-family: Arial;
   font-size: 10pt;
  }
  </style>
  </head>
  <body>
  <span style="font-weight: bold; font-size: 15pt;">密码生成器</span><br /><br />
  <?php
   
  if (isset($_GET['password_length'])){
   if(preg_match("/([0-9]{1,8})/", $_GET['password_length'])){
    print("密码生成成功:<br />
  <span style="font-weight: bold">" . gen_random_password($_GET['password_length']) . "</span><br /><br />n");
   } else {
    print("密码长度不正确!<br /><br />n");
   }  //开源软件:phpfensi.com
  }
   
  print <<< end
  请为密码生成其指定生成密码的长度:<br /><br />
  <form action="{$_SERVER['PHP_SELF']}" method="get">
   <input type="text" name="password_length">
   <input type="submit" value="生成">
  </form>
  end;  
  ?>
  </body>
  </html>

(编辑:甘孜站长网)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    热点阅读