Fonction  crypte() de PHP

Définition et usage La fonction crypt()


PHP references des fonctions PHP

(PHP 4, PHP 5)

crypt — Hachage à sens unique (indéchiffrable)

La fonction crypt()

La fonction crypte() renvoie une chaîne chiffrée utilisant le DES, le Blowfish, ou les algorithmes MD5, ou bien un des algorithmes disponibles sur la machine.

Certains systèmes supportent plus d'un type de hachage. En fait, il arrive que le chiffrement DES standard soit remplacé par un algorithme de chiffrement MD5. Le choix du type de hachage est effectué en se basant sur la valeur du salt. À l'installation, PHP détermine les possibilités de la fonction crypt(), et acceptera des salt pour d'autres types de chiffrements. Si aucun salt n'est fourni, PHP va en générer deux caractères (DES), à moins que le système par défaut soit MD5, auquel cas un salt compatible MD5 sera généré. PHP définit une constante appelée CRYPT_SALT_LENGTH permettant de vous indiquer la longueur du salt disponible pour le système de hachage utilisé.

crypt(), lorsqu'elle est utilisée avec le chiffrement standard DES, retourne le salt dans les deux premiers caractères de la chaîne retournée. Elle n'utilise que les 8 premiers caractères de str, ce qui fait que toutes les chaînes plus longues, qui ont les mêmes premiers 8 octets retourneront le même résultat (tant que le salt est toujours le même).

Sur les systèmes où crypt() supporte plusieurs types de hachages, les constantes suivantes sont mises à 0 ou 1, suivant que le type correspondant est disponible :

 Constantes :

  • CRYPT_STD_DES : chiffrement DES standard à 2 caractères depuis la classe de caractères "./0-9A-Za-z". L'utilisation de caractères invalides dans le salt fera échouer la fonction crypt().
  • CRYPT_EXT_DES : Hachage DES étendu. Le "salt" sera une chaîne de 9 caractères composé d'un underscore, suivi de 4 octets du compteur d'itération puis 4 octets du "salt". Ces caractères seront encodés en tant que caractères imprimables, 6 octets par caractère, et dont le premier caractère au moins sera significatif. Les valeurs de 0 à 63 seront encodés comme "./0-9A-Za-z". L'utilisation de caractères invalides dans le salt fera échouer la fonction crypt().
  • CRYPT_MD5 : hachage MD5 à 12 caractères commençant par $1$
  • CRYPT_BLOWFISH : hachage Blowfish dont le salt est composé comme ceci ; $2a$, un paramètre à 2 chiffres, $, et 22 base 64 chiffres depuis la classe de caractères "./0-9A-Za-z". L'utilisation de caractères en dehors de cette classe dans le salt fera que la fonction crypt() retournera une chaîne vide (de longueur 0). Le paramètre à 2 chiffres est le logarithme base-2 du compteur d'itération pour l'algorithme de hachage basé sur Blowfish sous jacent et doivent être dans l'intervalle 04-31. De la même façon, si vous utilisez une valeur en dehors de cet intervalle, la fonction crypt() échouera.
  • CRYPT_SHA256 - Hachage SHA-256 dont le salt est composé de 16 caractères préfixé par $5$. Si le salt commence par 'rounds=<N>$', la valeur numérique de N sera utilisée pour indiquer le nombre de fois que la boucle de hachage doit être exécutée, un peu comme le paramètre dans l'algorithme Blowfish. La valeur par défaut de rounds est de 5000, le minimum pouvant être de 1000 et le maximum, de 999,999,999. Tout autre sélection de N en dehors de cet intervalle sera tronqué à la plus proche des 2 limites.
  • CRYPT_SHA512 - Hachage SHA-512 dont le salt est composé de 16 caractères préfixé par $6$. Si le salt commence par 'rounds=<N>$', la valeur numérique de N sera utilisée pour indiquer le nombre de fois que la boucle de hachage doit être exécutée, un peu comme le paramètre dans l'algorithme Blowfish. La valeur par défaut de rounds est de 5000, le minimum pouvant être de 1000 et le maximum, de 999,999,999. Tout autre sélection de N en dehors de cet intervalle sera tronqué à la plus proche des 2 limites.
 Syntaxe

              crypt(str,salt)
           
 
Paramètre Description

Str

Requis. Spécifie la chaîne à coder

salt

Facultatif. Une chaîne employée pour augmenter le nombre de caractères codés, pour rendre le codage plus bloqué. Si l'argument de sel n'est pas fourni, il sera aléatoirement choisi par le PHP chaque fois que vous appelez cette fonction.


Notes :

 Il n'y a aucune fonction de déchiffrage. La fonction  crypte () emploie un algorithme à sens unique.


Exemple 1

Dans cet exemple nous examinerons l’utilisation de crypt() avec différents types de chiffrement

Sélectionner le code

              <?php            
              if (CRYPT_STD_DES == 1)            
              {            
              echo "Standard DES: ".crypt("j'aime PHP")."\n<br />";            
              }            
              else            
              {            
              echo "Standard DES n'est pas supporté.\n<br />";            
              }            
              if (CRYPT_EXT_DES == 1)            
              {            
              echo "Extended DES: ".crypt("j'aime PHP")."\n<br />";            
              }            
              else            
              {            
              echo "Extended DES n'est pas supporté.\n<br />";            
              }          
              if (CRYPT_MD5 == 1)            
              {            
              echo "MD5: ".crypt("j'aime PHP")."\n<br />";            
              }            
              else            
              {            
              echo "MD5 n'est pas supporté.\n<br />";            
              }            
              if (CRYPT_BLOWFISH == 1)            
              {            
              echo "Blowfish: ".crypt("j'aime PHP");            
              }            
              else            
              {            
              echo "Blowfish DES n'est pas supporté.";            
              }            
              ?>
           
 

Le résultat du code ci-dessus pourrait être (selon le du système d'exploitation) :


              Standard DES: $1$Yzxn9Dvo$0IQTkYefp8Ecxhn/8n8Ki0

Extended DES: $1$899yIcoW$KkFrTfvDN4pTTTSoso7ow/
MD5: $1$1zg2pkMH$G6iRByBTciuo0ECg7cnSR/
Blowfish: $1$8Gglxw4V$dMw0D8tFKer05Y.kuUT0Y/
Exemple 2

 Exemple avec crypt()

Sélectionner le code

   <?php
  // laissons le salt initialisé par PHP
  $password = crypt('mypassword');
  /*
    Il vaut mieux passer le résultat complet de crypt() comme salt nécessaire

    pour le chiffrement du mot de passe, pour éviter les problèmes entre les

    algorithmes utilisés (comme nous le disons ci-dessus, le chiffrement

    standard DES utilise un salt de 2 caractères, mais un chiffrement

    MD5 utilise un salt de 12).
  */
  if (crypt($user_input, $password) == $password) {

     echo "Mot de passe correct !";

  }
  ?>
            
 

Exemple 3

 Utilisation de crypt() avec htpasswd

Sélectionner le code

   <?php
  // Définition du mot de passe
  $password = 'mypassword';
  // Récupération du hash, on laisse le salt se générer automatiquement
  $hash = crypt($password);
	echo $hash;
  ?>               
           
 

Le résultat du code ci-dessus pourrait être (selon le du système d'exploitation) :


            $1$1uG5eAok$agluqX.sra1d0xlbQSg2W0                
           
 


Par carabde 22 Aout 2014