Maison > cadre php > Laravel > Développement Laravel : Comment chiffrer des données à l'aide de Laravel Encryption ?

Développement Laravel : Comment chiffrer des données à l'aide de Laravel Encryption ?

王林
Libérer: 2023-06-15 08:31:29
original
1901 Les gens l'ont consulté

Laravel est un excellent framework PHP. Son concept de conception est simple et élégant, tout en fournissant des fonctions puissantes et des interfaces API faciles à utiliser, ce qui est largement apprécié par les développeurs. Dans le framework Laravel, il est très pratique d'utiliser Laravel Encryption pour crypter des données. Cet article présentera l'utilisation de base de Laravel Encryption.

Qu'est-ce que le cryptage Laravel ?

Laravel Encryption est un moyen de crypter les données fournies par le framework Laravel. Il peut rapidement crypter et déchiffrer les données et est facile à utiliser. Il est très approprié pour une application dans le développement Laravel.

Lorsque nous devons stocker des données sensibles, telles que des mots de passe, des numéros de carte de crédit, etc., afin d'éviter de stocker directement du texte brut, les données doivent être cryptées pour éviter les problèmes de sécurité causés par une fuite de données sensibles. Laravel Encryption fournit l'algorithme de cryptage sécurisé AES-256-CBC pour garantir la sécurité des données.

Comment utiliser le cryptage Laravel ?

Laravel Encryption est très simple, suivez simplement les étapes ci-dessous pour effectuer les opérations de cryptage et de décryptage.

Étape 1 : Générer une clé

Dans Laravel Encryption, une clé ($key) est requise pour les opérations de cryptage et de déchiffrement. La façon de générer une clé est d'ajouter une variable APP_KEY dans le fichier .env et d'exécuter la commande suivante pour générer la clé :

php artisan key:generate
Copier après la connexion

La clé générée sera automatiquement stockée dans la variable APP_KEY du fichier .env.

Étape 2 : Chiffrer les données

Avant d'utiliser Laravel Encryption pour crypter des données, nous devons introduire la bibliothèque Laravel Crypt dans le code :

use IlluminateSupportFacadesCrypt;
Copier après la connexion

Laravel Encryption fournit la méthode encrypt() pour crypter rapidement les données :

$data = '需要加密的数据';
$encrypted_data = Crypt::encryptString($data);
Copier après la connexion

Étape 3 : Décrypter les données

Laravel Encryption fournit la méthode decrypt() pour décrypter rapidement les données :

$decrypted_data = Crypt::decryptString($encrypted_data);
Copier après la connexion

Application pratique

Ci-dessous, nous prenons une simple fonction de connexion comme exemple pour montrer comment utiliser Laravel Encryption pour crypter des données sensibles.

Lorsqu'un utilisateur s'inscrit, le mot de passe de l'utilisateur doit être stocké, mais afin d'éviter toute fuite du mot de passe de l'utilisateur, nous devons crypter le mot de passe. Lorsque l'utilisateur se connecte, nous devons comparer le mot de passe saisi par l'utilisateur avec le mot de passe dans la base de données. Cela nécessite que le mot de passe saisi par l'utilisateur soit crypté puis comparé.

Fonction d'enregistrement

Lorsque l'utilisateur s'inscrit, nous devons crypter le mot de passe saisi par l'utilisateur. Le code est le suivant :

use IlluminateSupportFacadesCrypt;
use AppUser;

$user = new User;
$user->name = '用户名';
$user->password = Crypt::encryptString('密码');
$user->save();
Copier après la connexion

Fonction de connexion

Lorsque l'utilisateur se connecte, nous devons crypter le mot de passe saisi par l'utilisateur. utilisateur puis utilisez-le avec Les mots de passe de la base de données sont comparés. Le code est le suivant :

use IlluminateSupportFacadesCrypt;
use IlluminateHttpRequest;
use AppUser;

public function login(Request $request)
{
    $user = User::where('name', $request->input('name'))->first();
    if (!$user || $user->password != Crypt::encryptString($request->input('password'))) {
        return '用户名或密码错误';
    }
    // 登录成功
}
Copier après la connexion

Résumé

Laravel Encryption est une méthode de cryptage de données simple et facile à utiliser fournie par le framework Laravel, qui peut garantir efficacement. la sécurité des données sensibles. Dans les applications réelles, il vous suffit de suivre les étapes ci-dessus pour terminer les opérations de cryptage et de décryptage. Le code est clair et concis et est très approprié pour une utilisation dans le développement Laravel.

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!

Étiquettes associées:
source:php.cn
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
Tutoriels populaires
Plus>
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal