"Si un ouvrier veut bien faire son travail, il doit d'abord affûter ses outils." - Confucius, "Les Entretiens de Confucius. Lu Linggong"
Page de garde > La programmation > Comment chiffrer en toute sécurité les mots de passe dans les fichiers de configuration avec Java ?

Comment chiffrer en toute sécurité les mots de passe dans les fichiers de configuration avec Java ?

Publié le 2024-11-17
Parcourir:575

How to Securely Encrypt Passwords in Configuration Files with Java?

Comment chiffrer en toute sécurité les mots de passe dans les fichiers de configuration

Le chiffrement des mots de passe stockés dans les fichiers de configuration est crucial pour protéger les données sensibles et empêcher tout accès non autorisé.

Utilisation Cryptage basé sur un mot de passe (PBE) en Java

Une méthode simple et efficace pour crypter et déchiffrer les mots de passe consiste à utiliser le cryptage basé sur un mot de passe (PBE) de Java. PBE vous permet de dériver une clé à partir d'un mot de passe à l'aide d'un algorithme sécurisé, tel que PBKDF2WithHmacSHA512.

Étapes de mise en œuvre

  1. Générer un sel : Créer un sel aléatoire pour rendre les attaques par force brute plus difficiles.
  2. Dériver la clé de cryptage : Utilisez SecretKeyFactory pour dériver une clé AES à partir du mot de passe et du sel à l'aide de l'algorithme PBKDF2WithHmacSHA512.
  3. Chiffrer le mot de passe : Initialisez un chiffrement avec l'algorithme AES/CBC/PKCS5Padding et chiffrez le mot de passe à l'aide de la clé dérivée.
  4. Stockez le mot de passe crypté : Stockez le mot de passe crypté avec le sel dans le fichier de configuration.
  5. Déchiffrer le mot de passe : Lors de la lecture du fichier, instanciez un chiffre avec le même algorithme et la même clé, déchiffrez le mot de passe à l'aide du sel et obtenez le texte brut d'origine.

Exemple de code

import javax.crypto.Cipher;
import javax.crypto.SecretKey;
import javax.crypto.SecretKeyFactory;
import javax.crypto.spec.IvParameterSpec;
import javax.crypto.spec.PBEKeySpec;
import javax.crypto.spec.SecretKeySpec;

// ...

SecretKeySpec key = createSecretKey(password.toCharArray(), salt, iterationCount, keyLength);
String encryptedPassword = encrypt(originalPassword, key);
// ...
String decryptedPassword = decrypt(encryptedPassword, key);

Stockage du mot de passe de cryptage

Un défi demeure : où stocker le mot de passe utilisé pour le cryptage. Les options incluent :

  • Obfusquer dans le fichier source : Stocker le mot de passe dans le code source et le masquer pour le rendre plus difficile à récupérer.
  • Fournir en tant que propriété système : Transmettez le mot de passe en tant que propriété système lors du démarrage du programme (par exemple, -DpropertyProtectionPassword=...).
  • Utilisez un magasin de clés : Utilisez un magasin de clés protégé par un mot de passe principal.

Il est important de noter qu'il est difficile de stocker en toute sécurité le mot de passe principal, mais ces méthodes peuvent améliorer la sécurité des mots de passe dans les fichiers de configuration par rapport au stockage de texte en clair.

Dernier tutoriel Plus>

Clause de non-responsabilité: Toutes les ressources fournies proviennent en partie d'Internet. En cas de violation de vos droits d'auteur ou d'autres droits et intérêts, veuillez expliquer les raisons détaillées et fournir une preuve du droit d'auteur ou des droits et intérêts, puis l'envoyer à l'adresse e-mail : [email protected]. Nous nous en occuperons pour vous dans les plus brefs délais.

Copyright© 2022 湘ICP备2022001581号-3