Метод Random::alphanumericString($length)делает то, что вы хотите. Если вы хотите создать это самостоятельно, не используйте какой-либо случайный источник, кроме встроенного PHP random_bytesили random_int.
каркать
Ответы:
164
Сначала создайте строку со всеми возможными символами:
Вы также можете использовать range (), чтобы сделать это быстрее.
Затем в цикле выберите случайное число и используйте его в качестве индекса для $charactersстроки, чтобы получить случайный символ, и добавьте его в свою строку:
Эта реализация также удобна, если вы хотите удалить символы, которые выглядят одинаково, например, «l» и «1», «O» и «0». Это полезно при создании новых паролей для пользователей.
Марк Нолд, 07
10
Я также использую эту технику и удаляю все гласные, чтобы случайно не дать кому-нибудь что-нибудь грубое за пароль.
nickf
10
Незначительное улучшение: mt_rand()это простая замена rand(), и лучше.
Grilse
11
Выполнение strlen()каждой итерации нехорошо. Присвойте strlen($characters) - 1переменной и выполните strlen вне цикла. В данном случае не критично, но это просто Моветон .
mintobit
6
Подумайте об использовании random_int, если вам нужно криптографически безопасное случайное число.
PHP7 представил random_x()функции, которые должны быть еще лучше. Если вы пришли из PHP 5.X, используйте отличную библиотеку paragonie / random_compat, которая представляет собой полифил для random_bytes () и random_int () из PHP 7.
Используйте таблицу 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;
Это хорошо, хотя не буквенно-цифровые символы попадают в этот диапазон ACSII.
Bower
4
Я знаю, что это старый пост, но я хотел бы внести свой вклад в созданный мной класс на основе ответа Джереми Рутена и улучшенный предложениями в комментариях:
Простые ребята .... но помните, что каждый байт случайный от 0 до 255, что для случайной строки будет нормально. Также помните, что у вас будет два символа для представления каждого байта.
$str = bin2hex(random_bytes(32)); // 64 character string returned
Вы можете использовать следующий код. Это похоже на существующие функции, за исключением того, что вы можете принудительно подсчитать специальные символы:
Если вам нужен очень простой способ сделать это, вы можете положиться на существующие функции PHP. Это код, который я использую:
substr( sha1( time() ), 0, 15 )
time()дает вам текущее время в секундах с начала эпохи, sha1()шифрует его до строки 0-9a-f и substr()позволяет вам выбрать длину. Вам не обязательно начинать с символа 0, и независимо от разницы между двумя числами будет длина строки.
Он делает то же самое, что и у Джереми, но использует объединенные массивы, где он использует строку, и использует count (), где он использует strlen ().
У вас разное количество символов в строчных и прописных строках. И есть ли у этого кода преимущества перед всеми другими уже опубликованными здесь вариантами?
Random::alphanumericString($length)
делает то, что вы хотите. Если вы хотите создать это самостоятельно, не используйте какой-либо случайный источник, кроме встроенного PHPrandom_bytes
илиrandom_int
.Ответы:
Сначала создайте строку со всеми возможными символами:
$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()
, и лучше.strlen()
каждой итерации нехорошо. Присвойтеstrlen($characters) - 1
переменной и выполните strlen вне цикла. В данном случае не критично, но это просто Моветон .Мне нравится эта функция для работы
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);
источник
Сгенерируйте криптографически стойкую случайную (потенциально) 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, которая представляет собой полифил для random_bytes () и random_int () из PHP 7.function randomString($length) { return bin2hex(random_bytes($length)); }
источник
Однострочное решение:
echo substr( str_shuffle( str_repeat( 'abcdefghijklmnopqrstuvwxyz0123456789', 10 ) ), 0, 7 );
Вы можете изменить параметр substr, чтобы установить другую длину для вашей строки.
источник
Используйте таблицу 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; } }
источник
Простые ребята .... но помните, что каждый байт случайный от 0 до 255, что для случайной строки будет нормально. Также помните, что у вас будет два символа для представления каждого байта.
$str = bin2hex(random_bytes(32)); // 64 character string returned
источник
Возможно, я что-то здесь упустил, но вот способ использования функции uniqid () .
источник
uniqid
никоим образом не является случайным. Это совершенно предсказуемо. Этот вопрос очень специфичен для поиска псевдослучайных строк.Я сделал следующую быструю функцию, чтобы просто поиграть с ней
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();
источник
Если вам нужен очень простой способ сделать это, вы можете положиться на существующие функции PHP. Это код, который я использую:
substr( sha1( time() ), 0, 15 )
time()
дает вам текущее время в секундах с начала эпохи,sha1()
шифрует его до строки 0-9a-f иsubstr()
позволяет вам выбрать длину. Вам не обязательно начинать с символа 0, и независимо от разницы между двумя числами будет длина строки.источник
Вот что я использую:
$cryptoStrong = true; // can be false $length = 16; // Any length you want $bytes = openssl_random_pseudo_bytes($length, $cryptoStrong); $randomString = bin2hex($bytes);
Вы можете увидеть документы для openssl_random_pseudo_bytes здесь , а документы для bin2hex здесь
источник
Джереми ответил великолепно. Если, как и я, вы не знаете, как реализовать 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 ().
источник
range('a','z');
1 строка:
$FROM = 0; $TO = 'zzzz'; $code = base_convert(rand( $FROM ,base_convert( $TO , 36,10)),10,36); echo $code;
источник
Современный способ сделать это с помощью типа 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; }
источник
Сначала перечислите желаемых персонажей
$chars = '0123456789abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ';
Используйте функцию str_shuffle ($ string). Эта функция предоставит вам случайно перемешанную строку.
$alpha=substr(str_shuffle($chars), 0, 50);
50 - длина строки.
источник
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; }
источник