生成(伪)随机字母数字字符串
Posted
技术标签:
【中文标题】生成(伪)随机字母数字字符串【英文标题】:Generating (pseudo)random alpha-numeric strings 【发布时间】:2010-09-08 01:37:20 【问题描述】:如何在 php 中,例如:'d79jd8c'?
【问题讨论】:
解决方案简短而独特。参考这个链接***.com/a/34467730/4345141Random::alphanumericString($length)
方法可以满足您的需求。如果你想自己构建,不要使用 PHP 内置的 random_bytes
或 random_int
以外的任何随机源。
【参考方案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;
查看更多:
chr函数 mt_rand函数【讨论】:
这很好,虽然非字母数字字符在 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 here和Docs 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;
【讨论】:
小写和大写字符串中的字符数不同。与已在此处发布的所有其他变体相比,此代码是否有任何优势?以上是关于生成(伪)随机字母数字字符串的主要内容,如果未能解决你的问题,请参考以下文章