Генерування (псевдо) випадкових буквено-цифрових рядків


85

Як я можу сформувати (псевдо) випадковий буквено-цифровий рядок, щось на зразок: 'd79jd8c' у PHP?


Рішення коротке та унікальне. Посилання за цим посиланням stackoverflow.com/a/34467730/4345141
Saud Khan

Метод Random::alphanumericString($length)робить те, що ви хочете. Якщо ви хочете побудувати це самостійно, не використовуйте будь-яке випадкове джерело, крім вбудованого в PHP random_bytesабо random_int.
caw

Відповіді:


164

Спочатку створіть рядок з усіма можливими символами:

 $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 - довжина випадкового рядка.


9
Ця реалізація також приємна, якщо ви хочете видалити символи, які виглядають однаково, такі як "l" та "1", "O" та "0". Це варто при генерації нових паролів для користувачів.
Марк Нолд

10
Я також використовую цей прийом і видаляю всі голосні, щоб випадково не дати комусь щось грубе за пароль.
nickf

10
Невелике поліпшення: mt_rand()це незамінна заміна rand()і є кращим.
Grilse

11
Виконання strlen()кожної ітерації не є хорошим. Присвоїти strlen($characters) - 1змінну та виконати strlen поза циклом. У цьому випадку це не критично, але це просто тон Мове .
mintobit

6
Подумайте про використання random_int, якщо вам потрібен криптографічно захищений random.
reallynice

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);

14

Створіть криптографічно сильний, випадковий (потенційно) 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));
}

7

Рішення в один рядок:

echo substr( str_shuffle( str_repeat( 'abcdefghijklmnopqrstuvwxyz0123456789', 10 ) ), 0, 7 );

Ви можете змінити параметр substr, щоб встановити іншу довжину для вашого рядка.


4

За допомогою таблиці 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;

Побачити більше:


1
Це приємно, хоча нелітерально-цифрові символи потрапляють у цей діапазон ACSII.
Бауер

4

Я знаю, що це стара публікація, але я хотів би взяти участь у класі, який я створив на основі відповіді Джеремі Рутена та покращив пропозиціями в коментарях:

    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;

      }

    }

3

Прості хлопці .... але пам’ятайте, що кожен байт є випадковим між 0 і 255, що для випадкового рядка буде добре. Також пам’ятайте, що у вас буде два символи для представлення кожного байта.

$str = bin2hex(random_bytes(32));  // 64 character string returned

Безперечно найкраща відповідь і найкоротший код! Це повинно отримати більше голосів
Sliq


2

Я зробив наступну швидку функцію, щоб просто пограти з цією 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;
}

2

Ви можете використовувати наступний код. Це схоже на існуючі функції, за винятком того, що ви можете примусити підраховувати спеціальні символи:

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);
}

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();

1

Якщо ви хочете зробити це дуже простим способом, ви можете спиратися на існуючі функції PHP. Це код, який я використовую:

substr( sha1( time() ), 0, 15 )

time()надає вам поточний час у секундах з епохи, sha1()шифрує його до рядка 0-9a-f та substr()дозволяє вибрати довжину. Не потрібно починати з символу 0, і яка б різниця не була між двома числами, це довжина рядка.



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;
?>

Це робить точно те ж саме, що і у Джеремі, але використовує об’єднані масиви, де він використовує рядок, і використовує count (), де він використовує strlen ().


2
це повинно бутиrange('a','z');
Мехді Карамослі

0

1 рядок:

$FROM = 0; $TO = 'zzzz';
$code = base_convert(rand( $FROM ,base_convert( $TO , 36,10)),10,36);
echo $code;

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;
}

0

Спочатку перелічіть бажані символи

$chars = '0123456789abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ';

Використовуйте функцію str_shuffle ($ string). Ця функція надасть вам випадково перемішаний рядок.

$alpha=substr(str_shuffle($chars), 0, 50);

50 - довжина струни.


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;
}

У вас різна кількість символів у рядках нижнього та верхнього регістру. І чи має цей код якісь переваги перед усіма іншими варіантами, вже опублікованими тут?
magras
Використовуючи наш веб-сайт, ви визнаєте, що прочитали та зрозуміли наші Політику щодо файлів cookie та Політику конфіденційності.
Licensed under cc by-sa 3.0 with attribution required.