1
0
mirror of https://github.com/php/doc-fr.git synced 2026-03-29 18:42:07 +02:00
Files
archived-doc-fr/reference/strings/functions/crypt.xml
Yannick Torres f7a8933317 synch with EN Revision
git-svn-id: https://svn.php.net/repository/phpdoc/fr/trunk@158790 c90b9560-bf6c-de11-be94-00142212c4b1
2004-05-17 22:10:36 +00:00

140 lines
5.1 KiB
XML

<?xml version="1.0" encoding="iso-8859-1"?>
<!-- $Revision: 1.10 $ -->
<!-- EN-Revision: 1.3 Maintainer: yannick Status: ready -->
<refentry id="function.crypt">
<refnamediv>
<refname>crypt</refname>
<refpurpose>Chiffrage indéchiffrable (hashing)</refpurpose>
</refnamediv>
<refsect1>
<title>Description</title>
<methodsynopsis>
<type>string</type><methodname>crypt</methodname>
<methodparam><type>string</type><parameter>str</parameter></methodparam>
<methodparam choice="opt"><type>string</type><parameter>salt</parameter></methodparam>
</methodsynopsis>
<para>
<function>crypt</function> retourne la chaîne <parameter>str</parameter>
chiffrée avec l'algorithme standard Unix <abbrev>DES</abbrev>, ou bien
un des algorithmes disponibles sur la machine. L'argument
optionnel <parameter>salt</parameter> sera utilisé comme base pour le
chiffrement. Reportez vous aux pages de manuel Unix pour plus de détails
sur la fonction crypt.
</para>
<simpara>
Si l'argument <parameter>salt</parameter> n'est pas fourni, &php;
en générera un lui-même.
</simpara>
<simpara>
Certains systèmes supportent plus d'un type de chiffrement. En fait,
il arrive que le chiffrement DES standard soit remplacé par un
algorithme de chiffrement MD5. Le choix du type de chiffrement est
effectué en se basant sur la valeur du <parameter>salt</parameter>.
A l'installation, &php; détermine les possibitilités de
la fonction crypt(), et acceptera des <parameter>salt</parameter>
pour d'autres types de chiffrements. Si aucun <parameter>salt</parameter>
n'est fourni, &php; va en générer un de deux caractères, à moins que le
système par défaut soit MD5, auquel cas un <parameter>salt</parameter>
compatible MD5 sera généré. &php; définit une constante appelée
CRYPT_SALT_LENGTH qui vous dira si un <parameter>salt</parameter>
de deux caractères s'applique à votre système, ou bien si c'est
un <parameter>salt</parameter> de 12 caractères.
</simpara>
<simpara>
Si vous utilisez le <parameter>salt</parameter> généré, pensez bien que
le <parameter>salt</parameter> est généré une seule fois. Si vous appelez
cette fonction récursivement, cela peut avoir des impacts sur la sécurité
et l'apparence du résultat.
</simpara>
<simpara>
<function>crypt</function>, lorsqu'elle est utilisée avec
le chiffrement standard DES, retourne le <parameter>salt</parameter>
dans les deux premiers caractères de la chaîne retournée. Elle
n'utilise que les 8 premiers caractères de <parameter>str</parameter>,
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).
</simpara>
<simpara>
Sur les sytèmes où <function>crypt</function> supporte plusieurs types de
chiffrements, les constantes suivantes sont mises à 1 ou 0,
suivant que le type correspondant est disponible :
</simpara>
<itemizedlist>
<listitem>
<simpara>
CRYPT_STD_DES - Chiffrement DES standard à 2 caractères
</simpara>
</listitem>
<listitem>
<simpara>
CRYPT_EXT_DES - Chiffrement DES étendu à 9 caractères
</simpara>
</listitem>
<listitem>
<simpara>
CRYPT_MD5 - Chiffrement MD5 à 12 caractères commençant par $1$
</simpara>
</listitem>
<listitem>
<simpara>
CRYPT_BLOWFISH - Chiffrement Blowfish à 16 caractères commençant par $2$
</simpara>
</listitem>
</itemizedlist>
<note>
<simpara>
Il n'existe pas de fonction de déchiffrement, car la fonction <function>crypt</function>
utilise un algorithme à un seul sens (injection).
</simpara>
</note>
<example>
<title>Exemple avec <function>crypt</function></title>
<programlisting role="php">
<![CDATA[
<?php
// laissons le salt initialisé par &php;
$mot_de_passe = crypt("MonM0TdEPa&&e");
/*
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($utilisateur_input,$mot_de_passe_input) == $mot_de_passe) {
echo "Mot de passe correct!";
}
?>
]]>
</programlisting>
</example>
<simpara>
Voir aussi
<function>md5</function> et
<link linkend="ref.mcrypt">l'extension Mcrypt</link>.
</simpara>
</refsect1>
</refentry>
<!-- Keep this comment at the end of the file
Local variables:
mode: sgml
sgml-omittag:t
sgml-shorttag:t
sgml-minimize-attributes:nil
sgml-always-quote-attributes:t
sgml-indent-step:1
sgml-indent-data:t
indent-tabs-mode:nil
sgml-parent-document:nil
sgml-default-dtd-file:"../../../../manual.ced"
sgml-exposed-tags:nil
sgml-local-catalogs:nil
sgml-local-ecat-files:nil
End:
vim600: syn=xml fen fdm=syntax fdl=2 si
vim: et tw=78 syn=sgml
vi: ts=1 sw=1
-->