Maison >développement back-end >tutoriel php >Comment chiffrer et décrypter en utilisant PHP ?

Comment chiffrer et décrypter en utilisant PHP ?

WBOY
WBOYoriginal
2023-05-22 08:09:061677parcourir

PHP est un langage de script côté serveur populaire qui peut être utilisé pour créer des applications Web complexes. L'une des fonctions importantes est le cryptage et le déchiffrement des données sensibles. Dans cet article, nous verrons comment chiffrer et déchiffrer à l'aide de PHP.

  1. Algorithme de cryptage symétrique

L'algorithme de cryptage symétrique est l'une des méthodes de cryptage les plus courantes, également connue sous le nom de cryptage à clé unique. Il utilise la même clé pour crypter et déchiffrer les données. En PHP, nous pouvons implémenter le chiffrement symétrique en utilisant l'extension mcrypt. Voici un exemple d'utilisation de l'algorithme AES pour crypter et déchiffrer des données :

$plaintext = 'This is the plaintext';
$key = 'mysecretkey';

// Encrypt the data
$encrypted = base64_encode(mcrypt_encrypt(MCRYPT_RIJNDAEL_128, $key, $plaintext, MCRYPT_MODE_ECB));

// Decrypt the data
$decrypted = mcrypt_decrypt(MCRYPT_RIJNDAEL_128, $key, base64_decode($encrypted), MCRYPT_MODE_ECB);

echo $decrypted; // Output: This is the plaintext

Dans cet exemple, nous utilisons l'algorithme Rijndael 128 bits (également connu sous le nom d'algorithme AES) pour crypter et déchiffrer les données. . Tout d’abord, nous transmettons le texte brut et la clé à la fonction mcrypt_encrypt pour chiffrer les données. Ensuite, nous codons les données cryptées en utilisant le codage base64. Lors du décryptage des données, nous utilisons la fonction mcrypt_decrypt avec la même clé pour décrypter les données, et la fonction base64_decode pour restaurer les données pré-chiffrées. L'algorithme de chiffrement asymétrique utilise une paire de clés (clé publique et clé privée) pour chiffrer et déchiffrer les données. La clé publique est utilisée pour chiffrer les données, tandis que la clé privée est utilisée pour déchiffrer les données. En PHP, nous pouvons utiliser l'extension openssl pour implémenter le cryptage asymétrique. Voici un exemple d'utilisation de l'algorithme RSA pour crypter et déchiffrer des données :

$plaintext = 'This is the plaintext';
$public_key = openssl_pkey_get_public(file_get_contents('public.pem'));
$private_key = openssl_pkey_get_private(file_get_contents('private.pem'));

// Encrypt the data
openssl_public_encrypt($plaintext, $encrypted, $public_key);
$encrypted = base64_encode($encrypted);

// Decrypt the data
openssl_private_decrypt(base64_decode($encrypted), $decrypted, $private_key);

echo $decrypted; // Output: This is the plaintext
    Dans cet exemple, nous utilisons l'algorithme RSA pour crypter et déchiffrer des données. Tout d’abord, nous utilisons la fonction openssl_pkey_get_public et la fonction openssl_pkey_get_private pour obtenir respectivement la clé publique et la clé privée. Nous transmettons ensuite le texte brut à la fonction openssl_public_encrypt et à la clé publique pour chiffrer les données, puis utilisons le codage base64 pour représenter les données chiffrées. Lors du déchiffrement des données, nous utilisons la fonction openssl_private_decrypt et la clé privée pour déchiffrer les données, et utilisons la fonction base64_decode pour restaurer les données avant le cryptage.
Fonction de hachage

La fonction de hachage peut convertir un message de n'importe quelle longueur en une valeur de hachage de longueur fixe. Les fonctions de hachage courantes incluent MD5 et SHA-1. En PHP, nous pouvons utiliser la fonction de hachage pour calculer la valeur de hachage. Voici un exemple d'utilisation de l'algorithme MD5 pour calculer la valeur de hachage :

$data = 'This is the data';
$hash = md5($data);
echo $hash; // Output: 05a671c66aefea124cc08b76ea6d30bb
    Dans cet exemple, nous utilisons la fonction md5 pour calculer la valeur de hachage de $data et la générer à l'aide de l'instruction echo.
  1. Les fonctions de hachage sont couramment utilisées pour la vérification des mots de passe. Dans ce cas, nous utilisons souvent un « sel » pour augmenter la force du mot de passe. Le sel est une chaîne aléatoire ajoutée au mot de passe d'origine avant le calcul du hachage. Voici un exemple d'utilisation d'un sel pour calculer un hachage :
$password = 'mypassword';
$salt = '4f1f79d0f620c';

$hash = md5($password . $salt);
echo $hash; // Output: b9e7d3217eae9517d2b01a773688fc1f

Dans cet exemple, nous concaténons le mot de passe et le sel ensemble, puis calculons le hachage. Lors de la vérification du mot de passe, nous pouvons comparer le mot de passe saisi par l'utilisateur avec la valeur de hachage (y compris la valeur salt) stockée dans la base de données pour vérifier si le mot de passe est correct.

Lors de l'utilisation des fonctions de hachage, il convient de noter que la valeur de hachage ne peut pas être déchiffrée à l'envers. Par conséquent, les fonctions de hachage sont généralement utilisées pour vérifier l’intégrité des données plutôt que pour les chiffrer.

Résumé

Dans cet article, nous avons présenté les principales méthodes de cryptage et de décryptage à l'aide de PHP, notamment les algorithmes de cryptage symétriques, les algorithmes de cryptage asymétriques et les fonctions de hachage. En pratique, nous devons choisir différentes méthodes de cryptage en fonction de nos besoins réels. Quelle que soit la méthode de cryptage, vous devez faire attention à la sécurité et aux performances. Lors du cryptage et du déchiffrement des données sensibles, les meilleures pratiques doivent être suivies pour garantir la sécurité et l'intégrité des données.

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