Maison >Java >javaDidacticiel >Pourquoi mes chaînes AES/CBC décryptées en Java affichent-elles des octets initiaux incorrects ?

Pourquoi mes chaînes AES/CBC décryptées en Java affichent-elles des octets initiaux incorrects ?

DDD
DDDoriginal
2024-12-01 04:31:10346parcourir

Why are My Decrypted AES/CBC Strings in Java Showing Incorrect Initial Bytes?

Octets initiaux incorrects dans le décryptage Java AES/CBC

Lors de l'utilisation du cryptage AES/CBC en Java, des octets initiaux erronés peuvent apparaître dans le déchiffrement chaîne. Ce problème est dû à des paramètres de chiffrement inadéquats.

Pour déchiffrer le problème, assurez-vous que les étapes suivantes sont mises en œuvre :

  1. Initialisation correcte du chiffrement : Initialisez le chiffre de chiffrement avec à la fois la clé secrète et un vecteur d'initialisation (IV):
Cipher encryptCipher = Cipher.getInstance("AES/CBC/PKCS5Padding");
encryptCipher.init(Cipher.ENCRYPT_MODE, aesKey, ivParameterSpec);
  1. Vecteur d'initialisation (IV) : Incluez le IV dans l'initialisation du chiffrement pour garantir des textes chiffrés différents même avec des entrées et des clés identiques.
  2. Initialisation appropriée de InputStream : Initialisez le flux d'entrée pour le décryptage avec le chiffrement, pas les octets chiffrés :
CipherInputStream cipherInputStream = new CipherInputStream(inStream, decryptCipher);

En respectant ces étapes, les octets initiaux de la chaîne déchiffrée devraient maintenant être corrects, ce qui permet une extraction précise des informations.

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