Maison développement back-end tutoriel php Comment crypter et décrypter des données en PHP ?

Comment crypter et décrypter des données en PHP ?

May 12, 2023 am 08:07 AM
php加密算法 php数据加密函数 php数据解密函数

PHP est un langage de programmation open source côté serveur largement utilisé dans le domaine du développement Web. Les applications web impliquant souvent des informations sensibles des utilisateurs, comme des mots de passe, des numéros de carte bancaire, etc., il est particulièrement important de chiffrer et décrypter ces informations.

Cet article présentera comment crypter et déchiffrer des données en PHP, notamment les éléments suivants :

  1. Algorithmes de cryptage couramment utilisés et leurs caractéristiques
  2. Utiliser le cryptage MD5 en PHP
  3. Utiliser le cryptage sha1 en PHP
  4. En PHP Utiliser base64 encodage en PHP
  5. Utilisez la bibliothèque d'extension openssl en PHP pour le cryptage et le décryptage AES
  6. Étapes d'utilisation de la bibliothèque d'extension mcrypt pour le cryptage et le décryptage AES en PHP

1 Algorithmes de cryptage couramment utilisés et leurs caractéristiques

  1. Algorithme MD5 : A. algorithme de résumé de message couramment utilisé qui mappe une chaîne de n'importe quelle longueur en une valeur de sortie de 128 bits. Il est largement utilisé dans des domaines tels que le cryptage des données et les signatures électroniques.

Caractéristiques : L'algorithme MD5 est irréversible, c'est-à-dire que la valeur d'entrée ne peut pas être déduite de la valeur de sortie ; l'algorithme MD5 garantit que la valeur de sortie de la même entrée est la même. L'algorithme MD5 est facilement craqué par des attaques de collision ; .

  1. Algorithme SHA1 : un algorithme de hachage sécurisé, similaire à MD5, qui mappe une chaîne de n'importe quelle longueur en une valeur de sortie de 160 bits, avec de bonnes capacités de sécurité et anti-collision.

Caractéristiques : L'algorithme SHA1 est irréversible ; la longueur de la valeur de sortie de l'algorithme SHA1 est plus longue que celle de l'algorithme MD5, garantissant une meilleure sécurité. L'algorithme SHA1 ne peut pas empêcher complètement les attaques par collision.

  1. Encodage base64 : méthode d'encodage qui encode les données binaires en caractères ASCII hautement lisibles. Elle est largement utilisée dans le courrier électronique, les protocoles HTTP et d'autres domaines.

Caractéristiques : l'encodage base64 n'est pas un véritable algorithme de cryptage, juste une méthode d'encodage ; l'encodage base64 ne modifie pas le contenu des données, mais modifie uniquement la représentation des données ; l'encodage base64 peut augmenter la stabilité et la sécurité de la transmission des données ; .

  1. Algorithme AES : Advanced Encryption Standard, un algorithme de cryptage symétrique utilisé pour protéger la sécurité des données telles que les informations sensibles. L'algorithme AES est divisé en trois longueurs de clé : 128 bits, 192 bits et 256 bits.

Caractéristiques : L'algorithme AES est un cryptage symétrique, et la même clé est utilisée pour le cryptage et le déchiffrement ; l'algorithme AES a une meilleure sécurité et efficacité ; plus la longueur de clé utilisée par l'algorithme AES est longue, plus la sécurité est élevée ;

2. Utilisez le cryptage MD5 en PHP

Utilisez la fonction md5() en PHP pour crypter les chaînes avec MD5. L'exemple de code est le suivant :

$str = "hello world";
$encrypted_str = md5($str);
echo $encrypted_str;
Copier après la connexion

Le résultat de sortie est :

5eb63bbbe01eeed093cb22bb8f5acdc3
Copier après la connexion

3.

Utilisez la fonction sha1() en PHP pour effectuer le cryptage SHA1 sur les chaînes. L'exemple de code est le suivant :

$str = "hello world";
$encrypted_str = sha1($str);
echo $encrypted_str;
Copier après la connexion

Le résultat de sortie est :

2ef7bde608ce5404e97d5f042f95f89f1c232871
Copier après la connexion

4. Utilisez l'encodage base64 en PHP

Utilisez la fonction base64_encode(). en PHP pour encoder des caractères La chaîne est codée en base64 et la fonction base64_decode() peut être utilisée pour décoder la chaîne codée en base64. L'exemple de code est le suivant :

$str = "hello world";
$encoded_str = base64_encode($str);
echo $encoded_str . "
";  // 输出:aGVsbG8gd29ybGQ=
$decoded_str = base64_decode($encoded_str);
echo $decoded_str;    // 输出:hello world
Copier après la connexion

5. Utilisez la bibliothèque d'extension openssl en PHP pour le cryptage AES et. décryptage

Utilisez la bibliothèque d'extension openssl en PHP Effectuez le cryptage et le décryptage AES des données L'exemple de code est le suivant :

// AES加密
function encrypt($str, $key) {
    $iv_size = openssl_cipher_iv_length('AES-256-CBC');
    $iv = openssl_random_pseudo_bytes($iv_size);   // 生成随机IV
    $encrypted_str = openssl_encrypt($str, 'AES-256-CBC', $key, OPENSSL_RAW_DATA, $iv);
    $result = base64_encode($iv . $encrypted_str);
    return $result;
}

// AES解密
function decrypt($encrypted_str, $key) {
    $encrypted_str = base64_decode($encrypted_str);
    $iv_size = openssl_cipher_iv_length('AES-256-CBC');
    $iv = substr($encrypted_str, 0, $iv_size);
    $encrypted_str = substr($encrypted_str, $iv_size);
    $result = openssl_decrypt($encrypted_str, 'AES-256-CBC', $key, OPENSSL_RAW_DATA, $iv);
    return $result;
}

// 测试代码
$key = "12345678901234567890123456789012";   // AES密钥,32位
$str = "hello world";
$encrypted_str = encrypt($str, $key);
echo $encrypted_str . "
";
$decrypted_str = decrypt($encrypted_str, $key);
echo $decrypted_str . "
";
Copier après la connexion

Le résultat de sortie est :

7KdkeT91N7zg8WZrZ1Oehg==xsYlbGhMF8dNQXH1LqTwVw==
hello world
Copier après la connexion

6. Étapes pour utiliser la bibliothèque d'extension mcrypt pour le cryptage et le décryptage AES. en PHP

Utilisez la bibliothèque d'extension mcrypt pour le cryptage et le décryptage AES. Les étapes sont les suivantes :

  1. Chargez la bibliothèque d'extension mcrypt
extension_loaded('mcrypt');  // 检查是否已经加载mcrypt扩展库
Copier après la connexion
  1. Générez un IV aléatoire
$iv_size = mcrypt_get_iv_size(MCRYPT_RIJNDAEL_128, MCRYPT_MODE_CBC);
$iv = mcrypt_create_iv($iv_size, MCRYPT_RAND);
Copier après la connexion
  1. Utilisez la fonction mcrypt_encrypt() pour AES chiffrement
$encrypted_str = mcrypt_encrypt(MCRYPT_RIJNDAEL_128, $key, $str, MCRYPT_MODE_CBC, $iv);
Copier après la connexion
  1. Utilisez la fonction mcrypt_decrypt() pour le décryptage AES
$decrypted_str = mcrypt_decrypt(MCRYPT_RIJNDAEL_128, $key, $encrypted_str, MCRYPT_MODE_CBC, $iv);
Copier après la connexion
  1. Utilisez la fonction base64_encode() effectue un codage base64 sur les données cryptées
$encrypted_str = base64_encode($iv . $encrypted_str);
Copier après la connexion
  1. Utilisez la fonction substr() pour intercepter le IV et le texte chiffré parties dans les données cryptées
$iv_size = mcrypt_get_iv_size(MCRYPT_RIJNDAEL_128, MCRYPT_MODE_CBC);
$iv = substr($encrypted_str, 0, $iv_size);
$encrypted_str = substr($encrypted_str, $iv_size);
Copier après la connexion

L'exemple de code complet de cryptage et de décryptage AES est le suivant :

// AES加密
function encrypt($str, $key) {
    $iv_size = mcrypt_get_iv_size(MCRYPT_RIJNDAEL_128, MCRYPT_MODE_CBC);
    $iv = mcrypt_create_iv($iv_size, MCRYPT_RAND);    // 生成随机IV
    $encrypted_str = mcrypt_encrypt(MCRYPT_RIJNDAEL_128, $key, $str, MCRYPT_MODE_CBC, $iv);
    $result = base64_encode($iv . $encrypted_str);    // 对IV和密文进行base64编码
    return $result;
}

// AES解密
function decrypt($encrypted_str, $key) {
    $encrypted_str = base64_decode($encrypted_str);  // 对base64编码的字符串进行解码
    $iv_size = mcrypt_get_iv_size(MCRYPT_RIJNDAEL_128, MCRYPT_MODE_CBC);
    $iv = substr($encrypted_str, 0, $iv_size);       // 截取IV值
    $encrypted_str = substr($encrypted_str, $iv_size);    // 截取密文部分
    $result = mcrypt_decrypt(MCRYPT_RIJNDAEL_128, $key, $encrypted_str, MCRYPT_MODE_CBC, $iv);
    return $result;
}

// 测试代码
$key = "1234567890123456";       // AES密钥,16位
$str = "hello world";
$encrypted_str = encrypt($str, $key);
echo $encrypted_str . "
";
$decrypted_str = decrypt($encrypted_str, $key);
echo $decrypted_str . "
";
Copier après la connexion

Le résultat de sortie est :

Ym63V4DnBc/jk9bNNzlngQtdeecbBZ+E7IHvC6khMgg=
hello world
Copier après la connexion

Résumé :

Les méthodes ci-dessus sont différentes pour le cryptage et le décryptage des données en PHP. les algorithmes de chiffrement ont des caractéristiques différentes et des scénarios applicables. Les développeurs doivent choisir la méthode de chiffrement appropriée en fonction des besoins réels et des exigences de sécurité. Lorsque vous utilisez des méthodes de cryptage, vous devez également faire attention à la protection des clés et aux processus de cryptage pour éviter d'être attaqué par des pirates.

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 de ce site Web
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

Outils d'IA chauds

Undresser.AI Undress

Undresser.AI Undress

Application basée sur l'IA pour créer des photos de nu réalistes

AI Clothes Remover

AI Clothes Remover

Outil d'IA en ligne pour supprimer les vêtements des photos.

Undress AI Tool

Undress AI Tool

Images de déshabillage gratuites

Clothoff.io

Clothoff.io

Dissolvant de vêtements AI

AI Hentai Generator

AI Hentai Generator

Générez AI Hentai gratuitement.

Article chaud

R.E.P.O. Crystals d'énergie expliqués et ce qu'ils font (cristal jaune)
3 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Meilleurs paramètres graphiques
3 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Comment réparer l'audio si vous n'entendez personne
3 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
WWE 2K25: Comment déverrouiller tout dans Myrise
3 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌

Outils chauds

Bloc-notes++7.3.1

Bloc-notes++7.3.1

Éditeur de code facile à utiliser et gratuit

SublimeText3 version chinoise

SublimeText3 version chinoise

Version chinoise, très simple à utiliser

Envoyer Studio 13.0.1

Envoyer Studio 13.0.1

Puissant environnement de développement intégré PHP

Dreamweaver CS6

Dreamweaver CS6

Outils de développement Web visuel

SublimeText3 version Mac

SublimeText3 version Mac

Logiciel d'édition de code au niveau de Dieu (SublimeText3)

Travailler avec les données de session Flash dans Laravel Travailler avec les données de session Flash dans Laravel Mar 12, 2025 pm 05:08 PM

Laravel simplifie la gestion des données de session temporaires à l'aide de ses méthodes de flash intuitives. Ceci est parfait pour afficher de brefs messages, alertes ou notifications dans votre application. Les données ne persistent que pour la demande ultérieure par défaut: $ demande-

Curl dans PHP: Comment utiliser l'extension PHP Curl dans les API REST Curl dans PHP: Comment utiliser l'extension PHP Curl dans les API REST Mar 14, 2025 am 11:42 AM

L'extension PHP Client URL (CURL) est un outil puissant pour les développeurs, permettant une interaction transparente avec des serveurs distants et des API REST. En tirant parti de Libcurl, une bibliothèque de transfert de fichiers multi-protocol très respectée, PHP Curl facilite Efficient Execu

Misque de réponse HTTP simplifié dans les tests Laravel Misque de réponse HTTP simplifié dans les tests Laravel Mar 12, 2025 pm 05:09 PM

Laravel fournit une syntaxe de simulation de réponse HTTP concise, simplifiant les tests d'interaction HTTP. Cette approche réduit considérablement la redondance du code tout en rendant votre simulation de test plus intuitive. L'implémentation de base fournit une variété de raccourcis de type de réponse: Utiliser illuminate \ support \ faades \ http; Http :: faux ([[ 'google.com' => 'Hello World', 'github.com' => ['foo' => 'bar'], 'forge.laravel.com' =>

12 meilleurs scripts de chat PHP sur Codecanyon 12 meilleurs scripts de chat PHP sur Codecanyon Mar 13, 2025 pm 12:08 PM

Voulez-vous fournir des solutions instantanées en temps réel aux problèmes les plus pressants de vos clients? Le chat en direct vous permet d'avoir des conversations en temps réel avec les clients et de résoudre leurs problèmes instantanément. Il vous permet de fournir un service plus rapide à votre personnalité

Expliquez le concept de liaison statique tardive en PHP. Expliquez le concept de liaison statique tardive en PHP. Mar 21, 2025 pm 01:33 PM

L'article traite de la liaison statique tardive (LSB) dans PHP, introduite dans PHP 5.3, permettant une résolution d'exécution de la méthode statique nécessite un héritage plus flexible. Problème main: LSB vs polymorphisme traditionnel; Applications pratiques de LSB et perfo potentiel

Frameworks de personnalisation / d'extension: comment ajouter des fonctionnalités personnalisées. Frameworks de personnalisation / d'extension: comment ajouter des fonctionnalités personnalisées. Mar 28, 2025 pm 05:12 PM

L'article examine l'ajout de fonctionnalités personnalisées aux cadres, en se concentrant sur la compréhension de l'architecture, l'identification des points d'extension et les meilleures pratiques pour l'intégration et le débogage.

Caractéristiques de sécurité du cadre: protection contre les vulnérabilités. Caractéristiques de sécurité du cadre: protection contre les vulnérabilités. Mar 28, 2025 pm 05:11 PM

L'article traite des fonctionnalités de sécurité essentielles dans les cadres pour se protéger contre les vulnérabilités, notamment la validation des entrées, l'authentification et les mises à jour régulières.

See all articles