PHPで「d79jd8c」のような(疑似)ランダムな英数字の文字列を生成するにはどうすればよいですか?
Random::alphanumericString($length)
はあなたが望むことをします。これを自分でビルドする場合は、PHPの組み込みrandom_bytes
またはrandom_int
。以外のランダムなソースを使用しないでください。
PHPで「d79jd8c」のような(疑似)ランダムな英数字の文字列を生成するにはどうすればよいですか?
Random::alphanumericString($length)
はあなたが望むことをします。これを自分でビルドする場合は、PHPの組み込みrandom_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を実行します。この場合は重要ではありませんが、Mauvaisトンだけです。
openssl_random_pseudo_bytes関数を使用して、暗号的に強力なランダムな(潜在的に)8文字の文字列を生成します。
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を使用している場合は、PHP 7のrandom_bytes()およびrandom_int()のポリフィルである優れたparagonie / random_compatライブラリを使用してください。
function randomString($length)
{
return bin2hex(random_bytes($length));
}
ASCIIテーブルを使用して、文字の範囲を選択します。ここで、$ range_start、$ range_endは、ASCIIテーブルの10進列の値です。
この方法は、文字の範囲が別の文字列内で具体的に定義されている説明されている方法と比較して優れていることがわかりました。
// 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;
続きを見る:
古い投稿であることは知っていますが、Jeremy Rutenの回答に基づいて作成し、コメントの提案で改善したクラスに貢献したいと思います。
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;
}
}
ここで何かを見逃したかもしれませんが、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();
これは私が使用するものです:
$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;
?>
これはJeremyとまったく同じことを行いますが、文字列を使用する場合はマージされた配列を使用し、strlen()を使用する場合はcount()を使用します。
range('a','z');
本当のランダム性のためにtypehint / 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;
}
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;
}