如何在PHP中生成(伪)随机字母数字字符串,例如:“ d79jd8c”?
Random::alphanumericString($length)
可以满足您的需求。如果您想自己构建它,请不要使用PHP的内置random_bytes
或之外的任何随机源random_int
。
如何在PHP中生成(伪)随机字母数字字符串,例如:“ d79jd8c”?
Random::alphanumericString($length)
可以满足您的需求。如果您想自己构建它,请不要使用PHP的内置random_bytes
或之外的任何随机源random_int
。
Answers:
首先用所有可能的字符组成一个字符串:
$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
是随机字符串的长度。
mt_rand()
是的直接替代rand()
,并且更好。
使用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()的填充。
function randomString($length)
{
return bin2hex(random_bytes($length));
}
使用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;
查看更多:
我知道这是一篇过时的文章,但是我想为我根据杰里米·鲁滕的回答创建的课程做出贡献,并通过注释中的建议进行改进:
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;
}
}
我已经制作了以下快速功能,以便于使用该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;
}
您可以使用以下代码。它与现有功能相似,不同之处在于您可以强制特殊字符计数:
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);
}
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();
这是我使用的东西:
$cryptoStrong = true; // can be false
$length = 16; // Any length you want
$bytes = openssl_random_pseudo_bytes($length, $cryptoStrong);
$randomString = bin2hex($bytes);
杰里米的答案很好。如果像我一样不确定如何实现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');
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;
}