Maison > développement back-end > tutoriel php > Trois façons de générer des chaînes aléatoires en PHP

Trois façons de générer des chaînes aléatoires en PHP

墨辰丷
Libérer: 2023-03-30 11:54:01
original
9548 Les gens l'ont consulté

Cet article présente principalement trois méthodes de génération de chaînes aléatoires en PHP. Les amis intéressés peuvent s'y référer. J'espère qu'il sera utile à tout le monde.

Méthode 1

1 Générez un entier aléatoire compris entre 33 et 126, par exemple 35.

2. Convertissez 35 en caractère de code ASCII correspondant, tel que 35 correspondant à #.

3. Répétez les étapes ci-dessus 1 et 2 n fois pour vous connecter avec un mot de passe à n chiffres.

Cet algorithme utilise principalement deux fonctions. La fonction mt_rand (int $min, int $max) est utilisée pour générer des entiers aléatoires, où $min – $max est la plage de codes ASCII, ici c'est 33- 126, la plage peut être ajustée selon les besoins. Par exemple, 97 à 122 bits dans la table de codes ASCII correspondent aux lettres anglaises a-z. Pour plus de détails, veuillez vous référer à la table de codes ASCII utilisée ; pour convertir l'entier $ascii correspondant en le caractère correspondant.

function create_password($pw_length =  
{ 
$randpwd = ”; 
for ($i = 0; $i < $pw_length; $i++) 
{ 
$randpwd .= chr(mt_rand(33, 126)); 
} 
return $randpwd; 
} 
// 调用该函数,传递长度参数$pw_length = 6 
echo create_password(6);
Copier après la connexion

Méthode 2

1. Préréglez une chaîne de caractères $, comprenant un – z, A – Z, 0 – 9 et un caractère spécial.

2. Choisissez un caractère aléatoire dans la chaîne $chars.

3. Répétez la deuxième étape n fois pour obtenir un mot de passe de longueur n.

function generate_password( $length = 8 ) { 
// 密码字符集,可任意添加你需要的字符 
$chars = ‘abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789!@#$%^&*()-_ []{}<>~`+=,.;:/?|&#39;; 
$password = ”; 
for ( $i = 0; $i < $length; $i++ ) 
{ 
// 这里提供两种字符获取方式 
// 第一种是使用 substr 截取$chars中的任意一位字符; 
// 第二种是取字符数组 $chars 的任意元素 
// $password .= substr($chars, mt_rand(0, strlen($chars) – 1), 1); 
$password .= $chars[ mt_rand(0, strlen($chars) - 1) ]; 
} 
return $password; 
}
Copier après la connexion

Méthode 3

1. Préréglez un tableau de caractères $chars, comprenant a – z, A – Z, 0 – 9 et un caractère spécial.

2. Sélectionnez aléatoirement les éléments $length du tableau $chars via array_rand().

3. Selon le tableau de noms de clé obtenu $keys, retirez les caractères du tableau $chars et concaténez la chaîne. L’inconvénient de cette méthode est que les mêmes caractères ne seront pas récupérés de manière répétée.

function make_password( $length = 8 ) 
{ 
 
// 密码字符集,可任意添加你需要的字符 
$chars = array(‘a&#39;, ‘b&#39;, ‘c&#39;, ‘d&#39;, ‘e&#39;, ‘f&#39;, ‘g&#39;, ‘h&#39;, 
‘i&#39;, ‘j&#39;, ‘k&#39;, ‘l&#39;,&#39;m&#39;, ‘n&#39;, ‘o&#39;, ‘p&#39;, ‘q&#39;, ‘r&#39;, &#39;s&#39;, 
‘t&#39;, ‘u&#39;, ‘v&#39;, ‘w&#39;, ‘x&#39;, ‘y&#39;,&#39;z&#39;, ‘A&#39;, ‘B&#39;, ‘C&#39;, ‘D&#39;, 
‘E&#39;, ‘F&#39;, ‘G&#39;, ‘H&#39;, ‘I&#39;, ‘J&#39;, ‘K&#39;, ‘L&#39;,&#39;M&#39;, ‘N&#39;, ‘O&#39;, 
‘P&#39;, ‘Q&#39;, ‘R&#39;, ‘S&#39;, ‘T&#39;, ‘U&#39;, ‘V&#39;, ‘W&#39;, ‘X&#39;, ‘Y&#39;,&#39;Z&#39;, 
‘0′, ‘1′, ‘2′, ‘3′, ‘4′, ‘5′, ‘6′, ‘7′, ‘8′, ‘9′, ‘!&#39;, 
‘@&#39;,&#39;#&#39;, ‘$&#39;, ‘%&#39;, ‘^&#39;, ‘&&#39;, ‘*&#39;, ‘(‘, ‘)&#39;, ‘-&#39;, ‘_&#39;, 
‘[&#39;, &#39;]‘, ‘{‘, ‘}&#39;, ‘<&#39;, ‘>&#39;, ‘~&#39;, ‘`&#39;, ‘+&#39;, ‘=&#39;, ‘,&#39;, 
‘.&#39;, ‘;&#39;, ‘:&#39;, ‘/&#39;, ‘?&#39;, ‘|&#39;); 
 
// 在 $chars 中随机取 $length 个数组元素键名 
$keys = ($chars, $length); 
$password = ”; 
for($i = 0; $i < $length; $i++) 
{ 
// 将 $length 个数组元素连接成字符串 
$password .= $chars[$keys[$i]]; 
} 
return $password; 
}
Copier après la connexion

Comparaison de l'efficacité du temps

Nous utilisons le code PHP suivant pour calculer le mot de passe à 6 chiffres généré par les 3 mots de passe aléatoires ci-dessus fonctions de génération Temps d'exécution, puis faites une comparaison simple de leur efficacité temporelle. Le résultat final est :

Première méthode : 9,8943710327148E-5 secondes
Méthode deux : 9,6797943115234E-5 secondes
Méthode trois : 0,00017499923706055 secondes
Vous pouvez voir la méthode. le temps d'exécution de la méthode 1 et de la méthode 2 est similaire, tandis que le temps d'exécution de la méthode 3 est légèrement plus long.

Résumé : Ce qui précède est l'intégralité du contenu de cet article, j'espère qu'il sera utile à l'étude de chacun.

Recommandations associées :

PHP pour implémenter la fonction de code de vérification de connexion

Fonction de notification de message gratuite, en utilisant PHP Comment écrire l’interface dans Telegram ?

Cas de remboursement WeChat de développement PHP

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

source:php.cn
Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn
Tutoriels populaires
Plus>
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal