Rumah >Java >javaTutorial >Mengapa Penyahsulitan Java AES/CBC Saya Menghasilkan Plaintext yang rosak?

Mengapa Penyahsulitan Java AES/CBC Saya Menghasilkan Plaintext yang rosak?

Linda Hamilton
Linda Hamiltonasal
2024-12-14 11:43:09691semak imbas

Why Does My Java AES/CBC Decryption Produce Corrupted Plaintext?

Teks Sifir Disulitkan Mengandungi Bait Permulaan Cacat dalam Java AES/CBC

Dalam kod yang disediakan, selepas penyahsulitan menggunakan AES/CBC dengan padding PKCS5, bahagian awal plaintext kelihatan rosak.

Akar Punca

Isu ini berpunca daripada pengabaian untuk menukar bait yang disulitkan dan dinyahsulit kepada rentetan. Dalam gelung penyahsulitan, output sifir ditulis terus ke aliran output. Akibatnya, bait pertama teks biasa, yang mengandungi maklumat padding, ditafsirkan secara salah sebagai sebahagian daripada mesej.

Penyelesaian

Untuk menyelesaikan masalah ini, tukarkan teks sifir dan teks biasa kepada rentetan menggunakan pengekodan aksara yang sesuai. Ini memastikan bahawa padding dikendalikan dengan betul dan plaintext dipaparkan dengan tepat.

Contoh Kod Yang Diperbaik

// Before encryption, encode the plaintext as a string
byte[] plaintextBytes = "Hello there. How are you? Have a nice day.".getBytes(StandardCharsets.UTF_8);
// ... encrypt and decrypt as before ...

// Convert the decrypted bytes to a string
String decryptedText = new String(decryptedBytes, StandardCharsets.UTF_8);
System.out.println("Decrypted text: " + decryptedText);

Atas ialah kandungan terperinci Mengapa Penyahsulitan Java AES/CBC Saya Menghasilkan Plaintext yang rosak?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Kenyataan:
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn