Pergunta

Como posso gerar uma string alfanumérica (pseudo) aleatória, algo como:'d79jd8c' em PHP?

Foi útil?

Solução

Primeiro faça uma string com todos os seus caracteres possíveis:

 $characters = 'abcdefghijklmnopqrstuvwxyz0123456789';

Você também pode usar faixa() para fazer isso mais rapidamente.

Então, em um loop, escolha um número aleatório e use-o como índice para o $characters string para obter um caractere aleatório e anexe-o à sua string:

 $string = '';
 $max = strlen($characters) - 1;
 for ($i = 0; $i < $random_string_length; $i++) {
      $string .= $characters[mt_rand(0, $max)];
 }

$random_string_length é o comprimento da string aleatória.

Outras dicas

Eu gosto dessa função para o trabalho

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

Gere uma string criptograficamente forte e aleatória (potencialmente) de 8 caracteres usando o openssl_random_pseudo_bytes função:

echo bin2hex(openssl_random_pseudo_bytes(4));

Forma processual:

function randomString(int $length): string
{
    return bin2hex(openssl_random_pseudo_bytes($length));
}

Atualizar:

PHP7 introduziu o random_x() funções que deveriam ser ainda melhores.Se você vem do PHP 5.X, use excelente paragonie/random_compat biblioteca que é um polyfill para bytes_aleatórios() e int_aleatório() do PHP 7.

function randomString($length)
{
    return bin2hex(random_bytes($length));
}

Solução de uma linha:

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

Você pode alterar o parâmetro substr para definir um comprimento diferente para sua string.

Use o Tabela ASCII para escolher um intervalo de letras, onde:$range_start , $range_end é um valor da coluna decimal na tabela ASCII.

Acho que esse método é melhor comparado para o método descrito onde o intervalo de caracteres é definido especificamente em outra string.

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

Ver mais:

Sei que é um post antigo, mas gostaria de contribuir com uma aula que criei com base na resposta de Jeremy Ruten e melhorei com sugestões nos comentários:

    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;

      }

    }

Talvez eu tenha perdido alguma coisa aqui, mas aqui está uma maneira de usar a função uniqid().

Eu criei a seguinte função rápida apenas para brincar com o range() função.Isso pode ajudar alguém em algum momento.

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

Caras simples....mas lembre-se de que cada byte é aleatório entre 0 e 255, o que para uma string aleatória será adequado.Lembre-se também de que você terá dois caracteres para representar cada byte.

$str = bin2hex(random_bytes(32));  // 64 character string returned
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();

Você pode usar o seguinte código, copiado de Este artigo.É semelhante às funções existentes, exceto que você pode forçar a contagem de caracteres especiais:

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

Se você quiser uma maneira muito fácil de fazer isso, você pode confiar nas funções PHP existentes.Este é o código que eu uso:

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

time() fornece a hora atual em segundos desde a época, sha1() criptografa-o em uma string de 0-9a-f e substr() permite que você escolha um comprimento.Você não precisa começar no caractere 0 e qualquer que seja a diferença entre os dois números, será o comprimento da string.

Isso é algo que eu uso:

$cryptoStrong = true; // can be false
$length = 16; // Any length you want
$bytes = openssl_random_pseudo_bytes($length, $cryptoStrong);
$randomString = bin2hex($bytes);

Você pode ver o Documentos para openssl_random_pseudo_bytes aqui, e a Documentos para bin2hex aqui

A resposta de Jeremy é ótima.Se, como eu, você não tem certeza de como implementar range(), você pode ver minha versão usando 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;
?>

Isso faz exatamente a mesma coisa que Jeremy, mas usa arrays mesclados onde ele usa uma string e usa count() onde ele usa strlen().

1 linha:

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

A maneira moderna de fazer isso com o tipo dica / rand_int para uma verdadeira aleatoriedade

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

Primeiro liste os caracteres desejados

$chars = '0123456789abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ';

Use a função str_shuffle($string).Esta função fornecerá uma string embaralhada aleatoriamente.

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

50 é o comprimento da string.

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;
}
Licenciado em: CC-BY-SA com atribuição
Não afiliado a StackOverflow
scroll top