如何生成(伪)随机字母数字字符串,例如:PHP中的'd79jd8c'?
答案 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 here和Docs 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;
}