O método Random::alphanumericString($length)faz o que você quiser. Se você quiser construir isso sozinho, não use nenhuma fonte aleatória diferente do embutido random_bytesou do PHP random_int.
caw
Respostas:
164
Primeiro, faça uma string com todos os seus caracteres possíveis:
Você também pode usar range () para fazer isso mais rapidamente.
Em seguida, em um loop, escolha um número aleatório e use-o como o índice da $charactersstring para obter um caractere aleatório e anexe-o à sua string:
Essa implementação também é boa se você deseja remover caracteres que parecem iguais, como "l" e "1", "O" e "0". Isso vale a pena ao gerar novas senhas para usuários.
Mark Nold
10
Também uso essa técnica e removo todas as vogais para não dar acidentalmente algo rude como senha.
nickf
10
Melhoria menor: mt_rand()é um substituto imediato para rand(), e é melhor.
Grilse de
11
Executar strlen()cada iteração não é bom. Atribua strlen($characters) - 1a uma variável e execute strlen fora do ciclo. Não é crítico neste caso, mas é apenas Mauvais ton .
mintobit
6
Considere o uso de random_int se precisar de um aleatório criptograficamente seguro.
O PHP7 introduziu as random_x()funções que deveriam ser ainda melhores. Se você vem do PHP 5.X, use a excelente biblioteca paragonie / random_compat que é um polyfill para random_bytes () e random_int () do PHP 7.
Use a 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 em comparação com 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;
Isso é bom, embora os caracteres não alfanuméricos estejam dentro da faixa ACSII.
Bower
4
Sei que é uma postagem antiga, mas gostaria de contribuir com uma aula que criei com base na resposta de Jeremy Ruten e melhorei com sugestões nos comentários:
Caras simples ... mas lembrem-se de que cada byte é aleatório entre 0 e 255, o que para uma string aleatória está bom. Lembre-se também de que você terá dois caracteres para representar cada byte.
$str = bin2hex(random_bytes(32)); // 64 character string returned
Se você deseja uma maneira muito fácil de fazer isso, pode confiar nas funções PHP existentes. Este é o código que uso:
substr( sha1( time() ), 0, 15 )
time()fornece o tempo 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.
$cryptoStrong = true; // can be false$length = 16; // Any length you want$bytes = openssl_random_pseudo_bytes($length, $cryptoStrong);
$randomString = bin2hex($bytes);
Você tem um número diferente de caracteres em strings minúsculas e maiúsculas. E esse código tem alguma vantagem sobre todas as outras variantes já publicadas aqui?
Random::alphanumericString($length)
faz o que você quiser. Se você quiser construir isso sozinho, não use nenhuma fonte aleatória diferente do embutidorandom_bytes
ou do PHPrandom_int
.Respostas:
Primeiro, faça uma string com todos os seus caracteres possíveis:
$characters = 'abcdefghijklmnopqrstuvwxyz0123456789';
Você também pode usar range () para fazer isso mais rapidamente.
Em seguida, em um loop, escolha um número aleatório e use-o como o índice da
$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.fonte
mt_rand()
é um substituto imediato pararand()
, e é melhor.strlen()
cada iteração não é bom. Atribuastrlen($characters) - 1
a uma variável e execute strlen fora do ciclo. Não é crítico neste caso, mas é apenas Mauvais ton .Eu gosto desta 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);
fonte
Gere uma string de 8 caracteres criptograficamente forte e aleatória (potencialmente) usando a função openssl_random_pseudo_bytes :
echo bin2hex(openssl_random_pseudo_bytes(4));
Forma processual:
function randomString(int $length): string { return bin2hex(openssl_random_pseudo_bytes($length)); }
Atualizar:
O PHP7 introduziu as
random_x()
funções que deveriam ser ainda melhores. Se você vem do PHP 5.X, use a excelente biblioteca paragonie / random_compat que é um polyfill para random_bytes () e random_int () do PHP 7.function randomString($length) { return bin2hex(random_bytes($length)); }
fonte
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.
fonte
Use a 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 em comparação com 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:
fonte
Sei que é uma postagem antiga, 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; } }
fonte
Caras simples ... mas lembrem-se de que cada byte é aleatório entre 0 e 255, o que para uma string aleatória está bom. Lembre-se também de que você terá dois caracteres para representar cada byte.
$str = bin2hex(random_bytes(32)); // 64 character string returned
fonte
Talvez eu tenha perdido algo aqui, mas aqui está uma maneira de usar a função uniqid () .
fonte
uniqid
não é aleatório de forma alguma. É totalmente previsível. Esta questão está procurando especificamente por strings pseudo-aleatórias.Eu fiz a seguinte função rápida apenas para brincar com a
range()
função. Isso só 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; }
fonte
Você pode usar o seguinte código. É 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_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); }
fonte
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();
fonte
Se você deseja uma maneira muito fácil de fazer isso, pode confiar nas funções PHP existentes. Este é o código que uso:
substr( sha1( time() ), 0, 15 )
time()
fornece o tempo atual em segundos desde a época,sha1()
criptografa-o em uma string de 0-9a-f esubstr()
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.fonte
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 Docs para openssl_random_pseudo_bytes aqui , e o Docs para bin2hex aqui
fonte
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 matrizes mescladas onde ele usa uma string e usa count () onde usa strlen ().
fonte
range('a','z');
1 linha:
$FROM = 0; $TO = 'zzzz'; $code = base_convert(rand( $FROM ,base_convert( $TO , 36,10)),10,36); echo $code;
fonte
A maneira moderna de fazer isso com o tipo hint / rand_int para randomeness real
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; }
fonte
Primeiro liste os caracteres desejados
$chars = '0123456789abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ';
Use a função str_shuffle ($ string). Esta função fornecerá a você uma string embaralhada aleatoriamente.
$alpha=substr(str_shuffle($chars), 0, 50);
50 é o comprimento da corda.
fonte
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; }
fonte