Расшифровка Android: ошибка при финализации шифра
Я использую Android для шифрования и шифрования изображений, передаваемых между приложениями.
Шифрование работает хорошо, но когда файл прибывает в место назначения, он не расшифровывается. Теперь я скопировал файл в целевом приложении и успешно расшифровал его с помощью стороннего программного обеспечения.
Я получаю сообщение об ошибке: «Ошибка при финализации шифра» в CipherInputStream (CipherInputStream.java:107), вызванная IllegalBlockSizeException.
Код шифрования и дешифрования приведен ниже:
public static String encrypt(String plainFile, String encryptedFile) throws IOException, NoSuchAlgorithmException,
NoSuchPaddingException, InvalidKeyException {
// Here you read the cleartext.
File extStore = Environment.getExternalStorageDirectory();
FileInputStream fis = new FileInputStream(plainFile);
// This stream write the encrypted text. This stream will be wrapped by
// another stream.
FileOutputStream fos = new FileOutputStream(encryptedFile);
// Length is 16 byte
SecretKeySpec sks = new SecretKeySpec("MyDifficultPassw".getBytes(), "AES");
// Create cipher
Cipher cipher = Cipher.getInstance("AES");
cipher.init(Cipher.ENCRYPT_MODE, sks);
// Wrap the output stream
CipherOutputStream cos = new CipherOutputStream(fos, cipher);
// Write bytes
int b;
byte[] d = new byte[8];
while ((b = fis.read(d)) != -1) {
cos.write(d, 0, b);
}
// Flush and close streams.
cos.flush();
cos.close();
fis.close();
return encryptedFile;
}
static String decrypt(String plainFile, String encryptedFile) throws IOException, NoSuchAlgorithmException,
NoSuchPaddingException, InvalidKeyException {
File encFile=new File(encryptedFile);
FileInputStream fis = new FileInputStream(encFile);
FileOutputStream fos = new FileOutputStream(plainFile);
SecretKeySpec sks = new SecretKeySpec("MyDifficultPassw".getBytes(),
"AES");
Cipher cipher = Cipher.getInstance("AES");
cipher.init(Cipher.DECRYPT_MODE, sks);
CipherInputStream cis = new CipherInputStream(fis, cipher);
int b;
byte[] d = new byte[8];
while ((b = cis.read(d)) != -1) {
fos.write(d, 0, b);
}
fos.flush();
fos.close();
cis.close();
return plainFile;
}
Есть идеи? Спасибо!
Ронан
Обновление: полученный зашифрованный файл последовательно на 1 байт меньше исходного файла, который, по-видимому, генерирует ошибку. Ошибка повторного размера блока запускается в строке кода, а ((b = fis.read (d))! = -1) {в функции расшифровки.
Обновление: спасибо за отзыв. Окончательное решение, как определено впоследний блок не завершен с CipherInputStream / CipherOutputStream, даже с заполнением AES / CBC / PKCS5Padding
Ронан