Итак, я работаю над личным проектом для себя, и я пытаюсь зашифровать файлы на своем телефоне. Эти файлы могут быть любыми документами, фотографиями и т.д. Сейчас я пытаюсь заставить это работать правильно. Когда я запускаю шифрование, он работает правильно и шифрует файлы. Когда я запускаю расшифровку, иногда это работает, а иногда - нет. Когда он терпит неудачу, я обычно получаю сообщение об ошибке "Ошибка при завершении шифрования, поврежденного блока". Я также не использую разные тестовые файлы, поэтому это не то, что некоторые файлы работают, а другие нет. Это те же два файла, которые я пробую каждый раз.
public static void encryptfile(String path,String Pass) throws IOException, NoSuchAlgorithmException, NoSuchPaddingException, InvalidKeyException {
FileInputStream fis = new FileInputStream(path);
FileOutputStream fos = new FileOutputStream(path.concat(".crypt"));
byte[] key = (salt + Pass).getBytes("UTF-8");
MessageDigest sha = MessageDigest.getInstance("SHA-1");
key = sha.digest(key);
key = Arrays.copyOf(key,16);
SecretKeySpec sks = new SecretKeySpec(key, "AES");
Cipher cipher = Cipher.getInstance("AES");
cipher.init(Cipher.ENCRYPT_MODE, sks);
CipherOutputStream cos = new CipherOutputStream(fos, cipher);
int b;
byte[] d = new byte[8];
while((b = fis.read(d)) != -1) {
cos.write(d, 0, b);
}
cos.flush();
cos.close();
fis.close();
}
public static void decrypt(String path,String Pass) throws IOException, NoSuchAlgorithmException, NoSuchPaddingException, InvalidKeyException {
FileInputStream fis = new FileInputStream(path);
FileOutputStream fos = new FileOutputStream(path.replace(".crypt",""));
byte[] key = (salt + Pass).getBytes("UTF-8");
MessageDigest sha = MessageDigest.getInstance("SHA-1");
key = sha.digest(key);
key = Arrays.copyOf(key,16);
SecretKeySpec sks = new SecretKeySpec(key, "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();
}
В настоящее время Соль и Пароль являются статическими и не меняются для целей тестирования. Все равно получайте ошибки примерно в половине случаев.
Есть ли у кого-нибудь идеи о том, почему это происходит? Я искал вокруг, и я нашел пару вещей, чтобы попробовать, ни одна из которых не работала. Я рассмотрел некоторые из следующих вопросов для решений:
Расшифровка Android: ошибка при завершении шифрования
Ошибка шифрования на Android 4.2
Ошибка дешифрования: "no iv set when one expected"
Как обрабатывать последний незавершенный блок в дешифровке
Шифрование и дешифрование файла изображения
Советы по шифрованию/расшифровке изображений в Java с помощью AES
Любая помощь очень ценится! Я думаю, что я просто пропустил что-то простое...
Update!
Люди были правы, когда это была соль. Когда я удалил соль, проблема была решена... Сделал немного больше копания, получается соль + Пасс был проблемой, а потому, что соль была байтом [], а Пасс - строкой. Я изменил соль на String, а затем использовал salt.concat(Pass), и проблема была решена!