87

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

4

18 回答 18

166

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

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

于 2008-09-07T04:06:09.227 回答
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);
于 2015-11-28T13:37:14.507 回答
14

使用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));
}
于 2016-02-24T14:41:48.680 回答
9

一线解决方案:

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

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

于 2017-08-08T19:55:36.200 回答
4

使用ASCII 表选择一系列字母,其中: $range_start 、 $range_end 是 ASCII 表中小数列的值。

我发现与在另一个字符串中专门定义字符范围的方法相比,这种方法更好。

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

看更多:

于 2008-09-07T10:04:46.413 回答
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;

      }

    }
于 2015-11-13T10:38:09.430 回答
3

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

$str = bin2hex(random_bytes(32));  // 64 character string returned
于 2019-05-02T14:59:29.447 回答
2

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

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);
}
于 2009-06-24T08:42:04.973 回答
2

也许我在这里遗漏了一些东西,但这是一种使用 uniqid() 函数的方法

于 2010-06-26T23:40:03.740 回答
2

我制作了以下快速功能只是为了使用该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;
}
于 2016-04-29T07:52:12.363 回答
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();
于 2015-03-08T10:48:58.503 回答
1

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

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

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

于 2018-04-16T14:51:02.877 回答
1

首先列出所需的字符

$chars = '0123456789abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ';

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

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

50 是字符串的长度。

于 2019-05-11T11:42:46.410 回答
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 的完全相同,但在他使用字符串的地方使用合并数组,在他使用 strlen() 的地方使用 count()。

于 2010-06-22T18:37:40.953 回答
0

这是我使用的东西:

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

您可以在此处查看 openssl_random_pseudo_bytes 的文档,并在此处查看 bin2hex 的文档

于 2016-12-28T11:44:00.493 回答
0

1行:

$FROM = 0; $TO = 'zzzz';
$code = base_convert(rand( $FROM ,base_convert( $TO , 36,10)),10,36);
echo $code;
于 2017-05-11T15:19:54.370 回答
0

使用类型提示 / 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;
}
于 2018-11-05T15:15:22.967 回答
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;
}
于 2019-05-11T11:48:37.233 回答