Maison  >  Article  >  développement back-end  >  Quatre façons de générer des chaînes avec des mots aléatoires en PHP

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

零到壹度
零到壹度original
2018-04-11 17:57:322022parcourir

Le contenu de cet article est de partager avec vous quatre méthodes pour générer des chaînes avec des mots aléatoires en PHP. Il a une certaine valeur de référence. Les amis dans le besoin peuvent s'y référer<.>

Les quatre méthodes de base pour générer des chaînes aléatoires sont présentées ci-dessous :

Méthode 1 :

1 , générez un entier aléatoire compris entre 33 et 126, tel que 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);


Méthode 2 :

1. Préréglez 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.

 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 .= $str{mt_rand(0,strlen($chars) - 1)};    
          //生成php随机数
            $password .= $chars[ mt_rand(0, strlen($chars) - 1) ];             }             return $password;            }


Méthode 3 :

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

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, prenez 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 =array_rand ($chars, $length); 
            $password = ”; 
           for($i = 0; $i < $length; $i++) 
          { 
             // 将 $length 个数组元素连接成字符串 
              $password .= $chars[$keys[$i]]; 
          } 
            return $password; 
         }

Méthode 4 :

Idée de base Cryptage md5 et génération de chaîne 32 bits mt_rand génère un nombre aléatoire dans une plage spécifiée
le temps peut obtenir un horodatage
Utilisez un nombre aléatoire + l'horodatage actuel pour obtenir un nombre aléatoire moins susceptible de se répéter

Le code est la suivante :

 $rand = md5(time() . mt_rand(0,1000));

Supplémentaire  : Ajoutez une accolade {} après la variable PHP et remplissez-la avec un nombre, qui fait référence à le caractère du numéro de série correspondant de la variable PHP.

Par exemple : $str = 'hello';
echo $str{0}; // La sortie est h
echo $str{1} ; / / La sortie est e
Si vous souhaitez vérifier si une certaine chaîne correspond à la longueur spécifiée, vous pouvez envisager d'utiliser des accolades (accolades) plus isset pour remplacer la fonction strlen car isset est une structure de langage et strlen l'est. une fonction, utiliser isset est plus efficace que d'utiliser strlen.
Par exemple, pour déterminer si la longueur d'une chaîne est inférieure à 5 :
if ( !isset ( $str{5} ) ) est meilleur que if ( strlen ( $str ) < 5 ).
                                                              

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!

Déclaration:
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