Dalam kod yang disediakan, selepas penyahsulitan menggunakan AES/CBC dengan padding PKCS5, bahagian awal plaintext kelihatan rosak.
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.
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.
// 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!