Maison >développement back-end >tutoriel php >Bibliothèque d'extensions de chiffrement PHP – Exemple d'utilisation de la bibliothèque d'extensions Mcrypt

Bibliothèque d'extensions de chiffrement PHP – Exemple d'utilisation de la bibliothèque d'extensions Mcrypt

黄舟
黄舟original
2017-05-25 16:14:004244parcourir

Bibliothèque d'extensions de chiffrement PHP—Bibliothèque d'extensions Mcrypt

Avant de commencer le texte principal de cet article, comprenons d'abord ce qu'est la bibliothèque d'extensions de chiffrement PHP : PHP En plus de plusieurs fonctions de chiffrement (md5, crypt, sha1), il existe également des bibliothèques complètes d'extensions de chiffrement en PHP ! Tout comme PHP ne prend pas en charge à l'origine le fonctionnement d'une certaine fonction, mais si vous souhaitez la prendre en charge dans la nouvelle version, vous pouvez la fournir de manière étendue. De cette manière, lorsque nous configurons PHP, si nous n'utilisons pas cette fonction, nous pouvons empêcher le chargement de PHP. Cela économise ainsi les ressources du serveur et améliore ses performances.

Dans les trois articles précédents "Fonction de cryptage PHP — cryptage de la fonction crypt()", "Fonction de cryptage PHP — cryptage de la fonction md5()" et "Fonction de cryptage PHP—chiffrement de la fonction sha1()" a introduit la fonction de cryptage PHP, nous vous présenterons donc ensuite la bibliothèque d'extension de cryptage PHP !

Il existe deux bibliothèques d'extensions de chiffrement PHP, Mcrypt et Mhash Dans cet article, nous présenterons d'abord Mcrypt !

1. >

mcypt est une bibliothèque d'extensions d'algorithmes de chiffrement très puissante. Mcrypt n'est pas installé lors du processus d'installation standard de PHP, mais le fichier libmcrypt.dll est inclus dans le répertoire personnel de PHP, nous utilisons donc uniquement le point-virgule devant la ligne extension=php_mcrypt.dll dans le fichier de configuration PHP "Supprimez-le ; , puis redémarrez le serveur pour utiliser cette bibliothèque d'extensions.

2.Constantes de la bibliothèque Mcrypt

La bibliothèque mcrypt prend en charge plus de 20 algorithmes de chiffrement et 8 modes de chiffrement Nous pouvons utiliser directement les fonctions mcrypt_list_algorithms() et mcrypt_list_modes( ) pour afficher, le code spécifique est le suivant :

<?php
$atr = mcrypt_list_algorithms();  //函数返回 Mcrypt支持的加密算法数组
echo "支持算法有:";
foreach ($atr as $atr_value){
    echo "<br>".$atr_value;
}
$arr = mcrypt_list_modes();     //函数返回 Mcrypt支持的加密模式数组
echo "<p>支持加密模式有:";
foreach ($arr as $arr_value){
    echo "<br>".$arr_value;
}
?>
Le résultat de sortie est :

Bibliothèque dextensions de chiffrement PHP – Exemple dutilisation de la bibliothèque dextensions Mcrypt

Remarque : Ces algorithmes et modes doivent être représentés par des constantes dans les applications pratiques. Lors de l'écriture, ajoutez les préfixes : MCRYPT_ et MCRYPT_MODE_ pour les représenter Exemple :

L'algorithme TWOFISH est exprimé comme : MCRYPT_TWOFISH.

Le mode de cryptage CBC est exprimé comme suit : MCRYPT_MODE_CBC.

3. Application Mcrypt

Utilisez Mcrypt pour le cryptage et le décryptage si vous ne souhaitez pas utiliser md5(), sha1() et d'autres fonctions, appelez simplement. eux directement. Afin que tout le monde comprenne clairement le flux de travail de Mcrypt, introduisons-le directement avec le code. Le code spécifique est le suivant :

<?php
header("Content-Type:text/html; charset=utf-8");
$str = "被加密的内容:PHH中文网www.php.cn";  //加密文本
$key = "key:111";                               //密钥
$cipher = MCRYPT_DES;                           //密码类型
$modes = MCRYPT_MODE_ECB;                      //密码模式
$iv = mcrypt_create_iv(mcrypt_get_iv_size($cipher,$modes),MCRYPT_RAND); //初始化向量
echo "加密前:".$str."<p>";
$str_encrypt = mcrypt_encrypt($cipher,$key,$str,$modes,$iv);       //加密函数
echo "加密后:".$str_encrypt."<p>";
$str_decrypt =mcrypt_decrypt($cipher,$key,$str_encrypt,$modes,$iv);  //解密函数
echo "还原:".$str_decrypt."<p>";
?>
Le résultat de sortie est :

<.>Bibliothèque dextensions de chiffrement PHP – Exemple dutilisation de la bibliothèque dextensions Mcrypt

Ci-dessous, nous présentons plusieurs fonctions qui apparaissent dans l'exemple ci-dessus :

1.mcrypt_create_iv :

Le format de syntaxe est le suivant :

Utilisez Mcrypt pour le cryptage des données. Avant le décryptage, un vecteur d'initialisation (appelé iv) doit d'abord être créé. La création d'un vecteur d'initialisation nécessite deux paramètres : size spécifie la taille de iv et source est la source de iv. source peut prendre les valeurs suivantes :
string mcrypt_create_iv ( int $size [, int $source = MCRYPT_DEV_URANDOM ] )

    MCRYPT_RAND : nombre aléatoire du système.
  • MCRYPT_DEV_RANDOM : Lire les données dans le répertoire /dev/random (système UNIX).
  • MCRYPT_DEV_URANDOM : Lire les données dans le répertoire /dev/urandom (système UNIX).
2.mcrypt_get_iv_size :

Format de syntaxe :

Le vecteur d'initialisation (iv) renvoyé par cette fonction taille. Les deux paramètres de la fonction sont l'algorithme de chiffrement (chiffrement) et le mode de chiffrement (mode) que nous venons d'introduire plus tôt.
int mcrypt_get_iv_size ( string $cipher , string $mode )

3.mcrypt_encrypt :

Le format de syntaxe est le suivant :

Après avoir initialisé le vecteur, vous pouvez utiliser mcrypt_encrypt() fonction de chiffrement pour chiffrer les données Chiffrement, les significations des cinq paramètres de cette fonction sont les suivantes :
string mcrypt_encrypt ( string $cipher , string $key , string $data , string $mode [, string $iv ] )

(1)cipher : algorithme de chiffrement. Dans l'exemple ci-dessus, il s'agit de la variable $cipher. L'algorithme de chiffrement peut ici être différent de l'algorithme de chiffrement dans le vecteur d'initialisation.

(2)clé : Clé. La variable $key dans l'exemple ci-dessus.

(3)mode : mode de cryptage.

(4)iv : Vecteur d'initialisation.

4.mcrypt_decrypt

Le format de syntaxe est le suivant :

Les paramètres de la fonction de décryptage mcrypt_decrypt() et de la fonction de cryptage mcrypt_encrypt() sont presque les mêmes. La seule différence réside dans les données de paramètres, où les données sont les données qui doivent être déchiffrées, et non les données d'origine.
string mcrypt_decrypt ( string $cipher , string $key , string $data , string $mode [, string $iv ] )

Remarque : Les paramètres de chiffrement, de clé et de mode dans la fonction de cryptage et la fonction de décryptage doivent être cohérents, sinon les données ne seront pas restaurées. Dans le prochain article, nous continuerons à présenter la bibliothèque d'extensions de chiffrement PHP : Bibliothèque d'extensions Mhash Pour plus de détails, veuillez lire "

Bibliothèque d'extensions de chiffrement PHP—Bibliothèque d'extensions Mhash

". ! 【Recommandations connexes】

1. Recommandations de sujets pertinents : "

Fonction de cryptage PHP

"

2.Bibliothèque d'extensions de chiffrement PHP-Bibliothèque d'extensions Mhash Exemple détaillé d'utilisation



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