【问题标题】:Generating (pseudo)random alpha-numeric strings生成(伪)随机字母数字字符串
【发布时间】:2010-09-08 01:37:20
【问题描述】:

如何在 PHP 中生成(伪)随机字母数字字符串,例如:'d79jd8c'?

【问题讨论】:

标签: php random


【解决方案1】:

首先创建一个包含所有可能字符的字符串:

 $characters = 'abcdefghijklmnopqrstuvwxyz0123456789';

您也可以使用range() 更快地完成此操作。

然后,在一个循环中,选择一个随机数并将其用作$characters 字符串的索引以获取随机字符,并将其附加到您的字符串中:

 $string = '';
 $max = strlen($characters) - 1;
 for ($i = 0; $i < $random_string_length; $i++) {
      $string .= $characters[mt_rand(0, $max)];
 }

$random_string_length是随机字符串的长度。

【讨论】:

  • 如果您希望删除看起来相同的字符,例如“l”和“1”、“O”和“0”,这个实现也很好。这在为用户生成新密码时是值得的。
  • 我也使用这种技术并删除所有元音,这样我就不会不小心给某人一些粗鲁的密码。
  • 小改进:mt_rand()rand() 的直接替代品,而且更好。
  • 每次迭代都执行strlen() 不好。将strlen($characters) - 1 分配给一个变量并在循环外执行strlen。在这种情况下并不重要,但它只是Mauvais ton
  • 如果您需要加密安全的随机数,请考虑使用random_int
【解决方案2】:

我喜欢这个功能

function randomKey($length) {
    $pool = array_merge(range(0,9), range('a', 'z'),range('A', 'Z'));

    for($i=0; $i < $length; $i++) {
        $key .= $pool[mt_rand(0, count($pool) - 1)];
    }
    return $key;
}

echo randomKey(20);

【讨论】:

    【解决方案3】:

    使用openssl_random_pseudo_bytes 函数生成加密强度高、随机(可能)8 个字符的字符串:

    echo bin2hex(openssl_random_pseudo_bytes(4));
    

    程序方式:

    function randomString(int $length): string
    {
        return bin2hex(openssl_random_pseudo_bytes($length));
    }
    

    更新:

    PHP7 引入了random_x() 函数,应该会更好。如果您来自 PHP 5.X,请使用优秀的 paragonie/random_compat 库,它是 PHP 7 中 random_bytes()random_int() 的 polyfill。

    function randomString($length)
    {
        return bin2hex(random_bytes($length));
    }
    

    【讨论】:

      【解决方案4】:

      一线解决方案:

      echo substr( str_shuffle( str_repeat( 'abcdefghijklmnopqrstuvwxyz0123456789', 10 ) ), 0, 7 );
      

      您可以更改 substr 参数以便为您的字符串设置不同的长度。

      【讨论】:

        【解决方案5】:

        使用ASCII table 选择一系列字母,其中: $range_start 、 $range_end 是 ASCII 表中十进制列中的值。

        我发现这种方法比 to the method described 更好,其中字符范围是在另一个字符串中专门定义的。

        // range is numbers (48) through capital and lower case letters (122)
        $range_start = 48;
        $range_end   = 122;
        $random_string = "";
        $random_string_length = 10;
        
        for ($i = 0; $i < $random_string_length; $i++) {
          $ascii_no = round( mt_rand( $range_start , $range_end ) ); // generates a number within the range
          // finds the character represented by $ascii_no and adds it to the random string
          // study **chr** function for a better understanding
          $random_string .= chr( $ascii_no );
        }
        
        echo $random_string;
        

        查看更多:

        【讨论】:

        • 这很好,虽然非字母数字字符在 ACSII 范围内。
        【解决方案6】:

        我知道这是一篇旧帖子,但我想为我根据 Jeremy Ruten 的回答创建的课程做出贡献,并通过 cmets 中的建议进行改进:

            class RandomString
            {
              private static $characters = 'abcdefghijklmnopqrstuvwxyz0123456789';
              private static $string;
              private static $length = 8; //default random string length
        
              public static function generate($length = null)
              {
        
                if($length){
                  self::$length = $length;
                }
        
                $characters_length = strlen(self::$characters) - 1;
        
                for ($i = 0; $i < self::$length; $i++) {
                  self::$string .= self::$characters[mt_rand(0, $characters_length)];
                }
        
                return self::$string;
        
              }
        
            }
        

        【讨论】:

          【解决方案7】:

          简单的家伙....但请记住,每个字节在 0 到 255 之间是随机的,对于随机字符串来说就可以了。另请记住,您将有两个字符来表示每个字节。

          $str = bin2hex(random_bytes(32));  // 64 character string returned
          

          【讨论】:

          • 迄今为止最好的答案和最短的代码!这应该会得到更多的支持
          【解决方案8】:

          也许我在这里漏掉了什么,但是here's a way using the uniqid() function

          【讨论】:

          • uniqid 在任何方面都不是随机的。这是完全可以预见的。这个问题非常专门寻找伪随机字符串。
          【解决方案9】:

          我制作了以下快速函数只是为了玩转range() 函数。有时它可能会对某人有所帮助。

          Function pseudostring($length = 50) {
          
              // Generate arrays with characters and numbers
              $lowerAlpha = range('a', 'z');
              $upperAlpha = range('A', 'Z');
              $numeric = range('0', '9');
          
              // Merge the arrays
              $workArray = array_merge($numeric, array_merge($lowerAlpha, $upperAlpha));
              $returnString = "";
          
              // Add random characters from the created array to a string
              for ($i = 0; $i < $length; $i++) {
                  $character = $workArray[rand(0, 61)];
                  $returnString .= $character;
              }
          
              return $returnString;
          }
          

          【讨论】:

            【解决方案10】:

            您可以使用以下代码。除了可以强制特殊字符计数之外,它与现有功能类似:

            function random_string() {
                // 8 characters: 7 lower-case alphabets and 1 digit
                $character_sets = [
                    ["count" => 7, "characters" => "abcdefghijklmnopqrstuvwxyz"],
                    ["count" => 1, "characters" => "0123456789"]
                ];
                $temp_array = array();
                foreach ($character_sets as $character_set) {
                    for ($i = 0; $i < $character_set["count"]; $i++) {
                        $random = random_int(0, strlen($character_set["characters"]) - 1);
                        $temp_array[] = $character_set["characters"][$random];
                    }
                }
                shuffle($temp_array);
                return implode("", $temp_array);
            }
            

            【讨论】:

              【解决方案11】:
              function generateRandomString($length = 10) {
                  $characters = '0123456789abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ';
                  $charactersLength = strlen($characters);
                  $randomString = '';
                  for ($i = 0; $i < $length; $i++) {
                      $randomString .= $characters[rand(0, $charactersLength - 1)];
                  }
                  return $randomString;
              }
              echo generateRandomString();
              

              【讨论】:

                【解决方案12】:

                如果您想要一个非常简单的方法来做到这一点,您可以依靠现有的 PHP 函数。这是我使用的代码:

                substr( sha1( time() ), 0, 15 )

                time() 为您提供自纪元以来的当前时间(以秒为单位),sha1() 将其加密为 0-9a-f 字符串,substr() 允许您选择长度。您不必从字符 0 开始,无论两个数字之间的差异是字符串的长度。

                【讨论】:

                  【解决方案13】:

                  首先列出所需的字符

                  $chars = '0123456789abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ';
                  

                  使用 str_shuffle($string) 函数。此函数将为您提供一个随机打乱的字符串。

                  $alpha=substr(str_shuffle($chars), 0, 50);
                  

                  50 是字符串的长度。

                  【讨论】:

                    【解决方案14】:

                    这是我使用的东西:

                    $cryptoStrong = true; // can be false
                    $length = 16; // Any length you want
                    $bytes = openssl_random_pseudo_bytes($length, $cryptoStrong);
                    $randomString = bin2hex($bytes);
                    

                    你可以看到Docs for openssl_random_pseudo_bytes hereDocs for bin2hex here

                    【讨论】:

                      【解决方案15】:

                      杰里米的回答很棒。如果像我一样不确定如何实现 range(),可以使用 range() 查看我的版本。

                      <?php
                      $character_array = array_merge(range('a', 'z'), range(0, 9));
                      $string = "";
                          for($i = 0; $i < 6; $i++) {
                              $string .= $character_array[rand(0, (count($character_array) - 1))];
                          }
                      echo $string;
                      ?>
                      

                      这与 Jeremy 的做法完全相同,但在他使用字符串的地方使用合并数组,在他使用 strlen() 的地方使用 count()。

                      【讨论】:

                      • 必须是range('a','z');
                      【解决方案16】:

                      1 行:

                      $FROM = 0; $TO = 'zzzz';
                      $code = base_convert(rand( $FROM ,base_convert( $TO , 36,10)),10,36);
                      echo $code;
                      

                      【讨论】:

                        【解决方案17】:

                        使用 type hint / rand_int 实现真正随机性的现代方法

                        function random_string(int $size): string
                        {
                            $characters = array_merge(
                                range(0, 9),
                                range('A', 'Z')
                            );
                        
                            $string = '';
                            $max = count($characters) - 1;
                            for ($i = 0; $i < $size; $i++) {
                                $string .= $characters[random_int(0, $max)];
                            }
                        
                            return $string;
                        }
                        

                        【讨论】:

                          【解决方案18】:
                          public function randomString($length = 8)
                          {
                              $characters = implode([
                                  'ABCDEFGHIJKLMNOPORRQSTUWVXYZ',
                                  'abcdefghijklmnoprqstuwvxyz',
                                  '0123456789',
                                  //'!@#$%^&*?'
                              ]);
                          
                              $charactersLength = strlen($characters) - 1;
                              $string           = '';
                          
                              while ($length) {
                                  $string .= $characters[mt_rand(0, $charactersLength)];
                                  --$length;
                              }
                          
                              return $string;
                          }
                          

                          【讨论】:

                          • 小写和大写字符串中的字符数不同。与已在此处发布的所有其他变体相比,此代码是否有任何优势?
                          猜你喜欢
                          • 1970-01-01
                          • 1970-01-01
                          • 2021-04-05
                          • 2011-08-18
                          • 1970-01-01
                          • 2013-10-10
                          • 1970-01-01
                          • 1970-01-01
                          • 1970-01-01
                          相关资源
                          最近更新 更多