Jer*_*ten 163
首先创建一个包含所有可能字符的字符串:
$characters = 'abcdefghijklmnopqrstuvwxyz0123456789';
Run Code Online (Sandbox Code Playgroud)
您还可以使用range()更快地完成此操作.
然后,在循环中,选择一个随机数并将其用作$characters字符串的索引以获取随机字符,并将其附加到您的字符串:
$string = '';
$max = strlen($characters) - 1;
for ($i = 0; $i < $random_string_length; $i++) {
$string .= $characters[mt_rand(0, $max)];
}
Run Code Online (Sandbox Code Playgroud)
$random_string_length 是随机字符串的长度.
aze*_*ati 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);
Run Code Online (Sandbox Code Playgroud)
emi*_*mix 13
使用openssl_random_pseudo_bytes函数生成加密强,随机(可能)的8个字符的字符串:
echo bin2hex(openssl_random_pseudo_bytes(4));
Run Code Online (Sandbox Code Playgroud)
程序方式:
function randomString(int $length): string
{
return bin2hex(openssl_random_pseudo_bytes($length));
}
Run Code Online (Sandbox Code Playgroud)
更新:
PHP7引入了random_x()应该更好的功能.如果您来自PHP 5.X,请使用优秀的paragonie/random_compat库,它是来自PHP 7的random_bytes()和random_int()的polyfill.
function randomString($length)
{
return bin2hex(random_bytes($length));
}
Run Code Online (Sandbox Code Playgroud)
一线解决方案:
echo substr( str_shuffle( str_repeat( 'abcdefghijklmnopqrstuvwxyz0123456789', 10 ) ), 0, 7 );
Run Code Online (Sandbox Code Playgroud)
您可以更改substr参数,以便为字符串设置不同的长度.