Maison > développement back-end > tutoriel php > Une brève introduction à la façon dont PHP génère des mots de passe aléatoires

Une brève introduction à la façon dont PHP génère des mots de passe aléatoires

黄舟
Libérer: 2023-03-14 20:42:02
original
1277 Les gens l'ont consulté


L'utilisation de PHP pour développer des applications, en particulier des programmes de sites Web, nécessite souvent de générer des mots de passe aléatoires. Par exemple, un mot de passe aléatoire est généré pour l'enregistrement de l'utilisateur, et un mot de passe aléatoire est également requis pour la réinitialisation de l'utilisateur. mot de passe. Un mot de passe aléatoire est une chaîne de longueur fixe. J'ai rassemblé ici plusieurs méthodes pour générer des chaînes aléatoires pour votre référence.

Méthode 1

  1. Générer un entier aléatoire de 33 à 126, tel que 35,

  2. convertir 35 en correspondant Caractères de code ASCII, tels 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

Instructions :

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, elle est 33-126. ajusté selon les besoins, comme les codes ASCII. Le bit 97 —— 122 dans le tableau correspond à a – z et 65 —— 90 correspond à la lettre anglaise de A —— Z Pour plus de détails, veuillez vous référer au tableau des codes ASCII.

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

Méthode 2

  1. Prérégler une chaîne $chars, comprenant a – z,A – Z,0 – 9, et quelques caractères spéciaux

  2. Choisissez au hasard un caractère dans la chaîne $chars

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

<?php
function generate_password( $length = 8 ) {
    // 密码字符集,可任意添加你需要的字符    
    $chars = &#39;abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789!@#$%^&*()-_[]{}<>~`+=,.;:/?|&#39;;    
    $password = &#39;&#39;;
    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;
}
echo generate_password(6);
Copier après la connexion

Méthode 3

  1. Préréglez un tableau de caractères $chars, y compris a – z,A – Z,0 – 9, et certains caractères spéciaux

  2. Utilisez array_rand() pour sélectionner au hasard $chars éléments $length

  3. du tableau

    selon le tableau de noms de clé obtenu $keys, et retirez les caractères d'épissage de caractères du tableau $chars 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.

<?phpfunction make_password( $length = 8 ) {
    // 密码字符集,可任意添加你需要的字符
    $chars = array(&#39;a&#39;, &#39;b&#39;, &#39;c&#39;, &#39;d&#39;, &#39;e&#39;, &#39;f&#39;, &#39;g&#39;, &#39;h&#39;, 
    &#39;i&#39;, &#39;j&#39;, &#39;k&#39;, &#39;l&#39;,&#39;m&#39;, &#39;n&#39;, &#39;o&#39;, &#39;p&#39;, &#39;q&#39;, &#39;r&#39;, &#39;s&#39;, 
    &#39;t&#39;, &#39;u&#39;, &#39;v&#39;, &#39;w&#39;, &#39;x&#39;, &#39;y&#39;,&#39;z&#39;, &#39;A&#39;, &#39;B&#39;, &#39;C&#39;, &#39;D&#39;, 
    &#39;E&#39;, &#39;F&#39;, &#39;G&#39;, &#39;H&#39;, &#39;I&#39;, &#39;J&#39;, &#39;K&#39;, &#39;L&#39;,&#39;M&#39;, &#39;N&#39;, &#39;O&#39;, 
    &#39;P&#39;, &#39;Q&#39;, &#39;R&#39;, &#39;S&#39;, &#39;T&#39;, &#39;U&#39;, &#39;V&#39;, &#39;W&#39;, &#39;X&#39;, &#39;Y&#39;,&#39;Z&#39;, 
    &#39;0&#39;, &#39;1&#39;, &#39;2&#39;, &#39;3&#39;, &#39;4&#39;, &#39;5&#39;, &#39;6&#39;, &#39;7&#39;, &#39;8&#39;, &#39;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;]&#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;?&#39;, &#39;|&#39;);    // 在 $chars 中随机取 $length 个数组元素键名
    $keys = array_rand($chars, $length); 

    $password = &#39;&#39;;    for($i = 0; $i < $length; $i++)
    {        // 将 $length 个数组元素连接成字符串
        $password .= $chars[$keys[$i]];
    }    return $password;
}echo make_password(6);
Copier après la connexion

Méthode 4

Utilisez md5 pour crypter l'horodatage actuel et intercepter certains chiffres. Le mot de passe généré ne contient que des lettres et des chiffres.

  1. time() Obtenez l'horodatage Unix actuel

  2. Cryptez l'horodatage obtenu lors de la première étape avec md5()

  3. Utilisez le résultat de la deuxième étape de cryptage et interceptez n chiffres pour obtenir le mot de passe souhaité

<?phpfunction get_password( $length = 8 )  {
    $str = substr(md5(time()), 0, $length);    return $str;
}echo get_password(6);
Copier après la connexion

Méthode 5

str_shuffle — Au hasard brouiller une chaîne

<?phpfunction random_pass( $length = 8 ){
    $password = &#39;&#39;;    
    $chars = &#39;abcdefghijkmnpqrstuvwxyz23456789ABCDEFGHIJKMNPQRSTUVWXYZ&#39;; //去掉1跟字母l防混淆            
    if ($length > strlen($chars)) {//位数过长重复字符串一定次数
        $chars = str_repeat($chars, ceil($length / strlen($chars)));
    }    $chars = str_shuffle($chars);    
    $password = substr($chars, 0, $length);    
    return $password;
}echo random_pass(6);
Copier après la connexion

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!

Étiquettes associées:
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