Как я могу сгенерировать (псевдо) случайную буквенно-цифровую строку, например: "d79jd8c" в PHP?
Генерирование (псевдо) случайных буквенно-цифровых строк
Ответ 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
- длина случайной строки.
Ответ 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
Генерируйте криптографически стойкую, случайную (потенциально) 8-символьную строку, используя функцию openssl_random_pseudo_bytes:
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, которая представляет собой polyfill для random_bytes() и random_int() из PHP 7.
function randomString($length)
{
return bin2hex(random_bytes($length));
}
Ответ 4
Однострочное решение:
echo substr( str_shuffle( str_repeat( 'abcdefghijklmnopqrstuvwxyz0123456789', 10 ) ), 0, 7 );
Вы можете изменить параметр substr, чтобы задать другую длину для вашей строки.
Ответ 5
Используйте таблицу 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;
Подробнее:
Ответ 6
Я знаю это старое сообщение, но я хотел бы внести свой вклад в класс, который я создал на основе ответа Джереми Рутена, и улучшился с предложениями в комментариях:
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
Возможно, я пропустил что-то здесь, но здесь, используя функцию uniqid().
Ответ 8
Я сделал следующую быструю функцию, чтобы играть с функцией 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;
}
Ответ 9
Вы можете использовать следующий код, скопированный из в эту статью. Он похож на существующие функции, за исключением того, что вы можете принудительно использовать специальный символ:
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);
}
Ответ 10
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();
Ответ 11
Если вы хотите очень простой способ сделать это, вы можете опираться на существующие функции PHP. Это код, который я использую:
substr( sha1( time()), 0, 15 )
time()
дает вам текущее время в секундах с начала эпохи, sha1()
шифрует его в строку 0-9a-f, а substr()
позволяет вам выбрать длину. Вам не нужно начинать с символа 0, и независимо от того, какая разница между этими двумя числами, будет длина строки.
Ответ 12
Простые ребята.... но помните, что каждый байт является случайным между 0 и 255, что для случайной строки будет хорошо. Также помните, что у вас будет два символа для представления каждого байта.
$str = bin2hex(random_bytes(32)); // 64 character string returned
Ответ 13
Ответ Джереми велик. Если, как и я, вы не знаете, как реализовать 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;
?>
Это делает то же самое, что и Джереми, но использует объединенные массивы, где он использует строку, и использует count(), где использует strlen().
Ответ 14
Это то, что я использую:
$cryptoStrong = true; // can be false
$length = 16; // Any length you want
$bytes = openssl_random_pseudo_bytes($length, $cryptoStrong);
$randomString = bin2hex($bytes);
Здесь вы можете увидеть Docs для openssl_random_pseudo_bytes, а Документы для bin2hex здесь
Ответ 15
1 строка:
$FROM = 0; $TO = 'zzzz';
$code = base_convert(rand( $FROM ,base_convert( $TO , 36,10)),10,36);
echo $code;
Ответ 16
Современный способ сделать это с типом подсказка /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;
}
Ответ 17
Сначала перечислите нужные символы
$chars = '0123456789abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ';
Используйте функцию str_shuffle ($ string). Эта функция предоставит вам случайно перемешанную строку.
$alpha=substr(str_shuffle($chars), 0, 50);
50 - длина строки.
Ответ 18
public function randomString($length = 8)
{
$characters = implode([
'ABCDEFGHIJKLMNOPORRQSTUWVXYZ',
'abcdefghijklmnoprqstuwvxyz',
'0123456789',
//'[email protected]#$%^&*?'
]);
$charactersLength = strlen($characters) - 1;
$string = '';
while ($length) {
$string .= $characters[mt_rand(0, $charactersLength)];
--$length;
}
return $string;
}