生成(伪)随机字母数字字符串

时间:2008-09-07 04:02:30

标签: php random

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

17 个答案:

答案 0 :(得分:158)

首先制作一个包含所有可能字符的字符串:

 $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是随机字符串的长度。

答案 1 :(得分:18)

我喜欢这个职能

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);

答案 2 :(得分:13)

使用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));
}

答案 3 :(得分:6)

一线解决方案:

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

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

答案 4 :(得分:4)

使用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;

查看更多:

答案 5 :(得分:4)

我知道这是一篇很老的帖子,但我想根据Jeremy Ruten的答案为我创建的课程做出贡献,并在评论中提出改进意见:

    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;

      }

    }

答案 6 :(得分:2)

也许我在这里遗漏了一些东西,但here's a way using the uniqid() function

答案 7 :(得分:2)

我已经制作了以下快速功能,只是为了使用exceptions功能。它可能会帮助某人。

range()

答案 8 :(得分:2)

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

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

答案 9 :(得分:1)

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();

答案 10 :(得分:1)

您可以使用从this article复制的以下代码。它与现有函数类似,只是您可以强制使用特殊字符:

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

答案 11 :(得分:1)

如果您想要一种非常简单的方法,您可以依靠现有的PHP功能。这是我使用的代码:

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

time()为您提供自纪元以来的当前时间,sha1()将其加密为0-9a-f的字符串,substr()可让您选择长度。你不必从字符0开始,两个数字之间的区别就是字符串的长度。

答案 12 :(得分:0)

杰里米的回答很棒。如果像我一样,你不确定如何实现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完全相同,但使用合并数组,他使用字符串,并使用count(),他使用strlen()。

答案 13 :(得分:0)

这是我使用的东西:

$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

答案 14 :(得分:0)

现代的方法是使用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;
}

答案 15 :(得分:0)

首先列出所需的字符

$chars = '0123456789abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ';

使用str_shuffle($ string)函数。此功能将为您提供随机混洗的字符串。

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

50是字符串的长度。

答案 16 :(得分:0)

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;
}