Maison >développement back-end >tutoriel php >Techniques de cryptage des données et de protection par mot de passe pour les bases de données PHP et Oracle

Techniques de cryptage des données et de protection par mot de passe pour les bases de données PHP et Oracle

PHPz
PHPzoriginal
2023-07-13 14:52:401452parcourir

Compétences en matière de cryptage des données et de protection par mot de passe pour les bases de données PHP et Oracle

Introduction :
À l'ère d'Internet d'aujourd'hui, la sécurité des données est devenue une tâche importante. Qu'il s'agisse des informations personnelles d'un utilisateur ou des secrets commerciaux d'une entreprise, les compétences en matière de cryptage des données et de protection par mot de passe sont particulièrement importantes. Cet article expliquera comment utiliser les bases de données PHP et Oracle pour mettre en œuvre des techniques de cryptage des données et de protection par mot de passe, et fournira des exemples de code pertinents.

1. Compétences en matière de cryptage des données

  1. Utiliser la fonction de hachage
    La fonction de hachage est une fonction qui mappe des données de longueur arbitraire à des données de longueur fixe. En PHP, vous pouvez utiliser la fonction de hachage pour réaliser cette fonction. Voici un exemple simple :
<?php
$data = "Hello World";
$hashed_data = hash('sha256', $data);
echo "Hashed Data: ".$hashed_data;
?>

Dans le code ci-dessus, nous utilisons l'algorithme SHA256 pour hacher la chaîne "Hello World" et afficher le résultat.

  1. Cryptage et déchiffrement symétriques
    Les algorithmes de cryptage symétriques utilisent la même clé pour le cryptage et le déchiffrement. En PHP, vous pouvez utiliser l'extension mcrypt pour implémenter le cryptage et le déchiffrement symétriques. Voici un exemple :
<?php
$salt = "abc123";
$data = "Hello World";
$key = md5($salt); //生成密钥
$encrypted_data = mcrypt_encrypt(MCRYPT_RIJNDAEL_128, $key, $data, MCRYPT_MODE_CBC);
$decrypted_data = mcrypt_decrypt(MCRYPT_RIJNDAEL_128, $key, $encrypted_data, MCRYPT_MODE_CBC);
echo "Encrypted Data: ".base64_encode($encrypted_data)."
";
echo "Decrypted Data: ".$decrypted_data."
";
?>

Dans le code ci-dessus, nous utilisons l'algorithme Rijndael-128 pour les opérations de chiffrement et de décryptage symétriques.

  1. Cryptage et décryptage asymétriques
    Les algorithmes de cryptage asymétriques utilisent des clés publiques pour crypter les données, tandis que des clés privées sont utilisées pour déchiffrer les données. En PHP, le cryptage et le déchiffrement asymétriques peuvent être implémentés à l'aide de l'extension openssl. Voici un exemple :
<?php
$data = "Hello World";
openssl_public_encrypt($data, $encrypted_data, $public_key);
openssl_private_decrypt($encrypted_data, $decrypted_data, $private_key);
echo "Encrypted Data: ".base64_encode($encrypted_data)."
";
echo "Decrypted Data: ".$decrypted_data."
";
?>

Dans le code ci-dessus, nous utilisons d'abord la clé publique pour crypter les données, puis utilisons la clé privée pour déchiffrer les données.

2. Compétences en matière de protection par mot de passe

  1. Utilisez la fonction de hachage pour stocker les mots de passe
    Lors du stockage des mots de passe utilisateur, les mots de passe en texte brut ne doivent pas être stockés directement dans la base de données. Au lieu de cela, le mot de passe doit être haché via une fonction de hachage avant d'être stocké. Voici un exemple :
<?php
$password = "password123";
$hashed_password = password_hash($password, PASSWORD_DEFAULT);
echo "Hashed Password: ".$hashed_password;
?>

Dans le code ci-dessus, nous utilisons la fonction password_hash pour hacher le mot de passe et afficher le résultat.

  1. Ajouter une valeur salt
    Pour augmenter la sécurité du mot de passe, vous pouvez ajouter une valeur salt générée aléatoirement au mot de passe de chaque utilisateur. Voici un exemple :
<?php
$password = "password123";
$salt = uniqid(mt_rand(), true);
$hashed_password = password_hash($password.$salt, PASSWORD_DEFAULT);
echo "Hashed Password: ".$hashed_password;
?>

Dans le code ci-dessus, nous générons d'abord une valeur salt aléatoire, puis concaténons le mot de passe et la valeur salt avant d'effectuer une opération de hachage.

  1. Complexité des mots de passe obligatoires
    Afin d'empêcher les utilisateurs d'utiliser des mots de passe trop simples, vous pouvez définir des exigences de complexité des mots de passe lors de l'enregistrement ou de la réinitialisation des mots de passe. Voici un exemple :
<?php
$password = "password123";
$pattern = "/^(?=.*[a-z])(?=.*[A-Z])(?=.*d)(?=.*[@#$%^&+=]).{8,}$/";
if(preg_match($pattern, $password)){
    echo "Password is strong";
} else {
    echo "Password is weak";
}
?>

Dans le code ci-dessus, nous utilisons des expressions régulières pour définir les exigences de complexité des mots de passe.

Conclusion : 
Grâce à l'introduction ci-dessus, nous avons appris à utiliser les bases de données PHP et Oracle pour mettre en œuvre des techniques de cryptage des données et de protection par mot de passe. Dans le développement réel, nous devons choisir des algorithmes de cryptage et des techniques de protection par mot de passe appropriés en fonction des besoins réels pour garantir la sécurité des données. Ce n'est que grâce à des mesures raisonnables de cryptage et de protection par mot de passe que la vie privée des utilisateurs et les secrets commerciaux de l'entreprise peuvent être protégés.

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