Форум программистов, компьютерный форум CyberForum.ru

Ошибка дешифровки AES в Android: pad block corrupted - Android

Войти
Регистрация
Восстановить пароль
 
Dimarzio
5 / 0 / 0
Регистрация: 12.08.2016
Сообщений: 3
12.08.2016, 09:45     Ошибка дешифровки AES в Android: pad block corrupted #1
Приветствую. В обучающих целях написал на Java программу для хранения паролей, использующую шифрование AES. Написал класс, в котором применяются методы из пакета javax.crypto. В приложении на Windows все отлично работает, шифрует и дешифрует. Решил сделать мобильную версию этого приложения на Android, для aes использовал тот же класс, но возникла проблема - данные не дешифруются, выкидывает исключение: javax.crypto.BadPaddingException: pad block corrupted. Почему так происходит?

Код моего класса:
Java
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
public class AES {
public static SecretKeySpec getSecretKeySpec(String data) {
try {
SecureRandom sr = SecureRandom.getInstance("SHA1PRNG");
            sr.setSeed(data.getBytes());
            KeyGenerator kg = KeyGenerator.getInstance("AES");
            kg.init(128, sr);
            return (new SecretKeySpec((kg.generateKey()).getEncoded(), "AES"));
        } catch (Exception e) {
          System.out.println("Ошибка при получении секретного ключа!");
        }
        return null;
    }
   public static byte[] encode(SecretKeySpec sks, byte[] data) {
        try {
            Cipher c = Cipher.getInstance("AES");
            c.init(Cipher.ENCRYPT_MODE, sks);
            return c.doFinal(data);
        }
        catch (Exception e){
         System.out.println("Ошибка операции шифрования!");
        }
    return null;
    }
 
 
public static byte[] decode(SecretKeySpec sks, byte[] data) {
try {
  Cipher c=Cipher.getInstance("AES");
  c.init(Cipher.DECRYPT_MODE,sks);
  return c.doFinal(data);
  }
 catch (Exception e) {
 System.out.println("Ошибка операции дешифровки");
  }
 return null;
 }
 }
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
12.08.2016, 09:45     Ошибка дешифровки AES в Android: pad block corrupted
Посмотрите здесь:

AES для Android Android
Android SDK Ошибка при запуске Android
Ошибка в Preferences в Android 4.4 Android
Android-support-v7 ошибка Android
Что за ошибка в Android Studio? Android
Android Studio ошибка с AVM manager Android
Импорт из Eclipse в Android Studio: ошибка Android
Ошибка установки android sdk Android
Ошибка при работе Android Studio Android
Android Ошибка при запуске Android Studio
Android Ошибка EndofMemory в Android
Ошибка R в Android Studio Android

Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
Dimarzio
5 / 0 / 0
Регистрация: 12.08.2016
Сообщений: 3
09.09.2016, 09:16  [ТС]     Ошибка дешифровки AES в Android: pad block corrupted #2
Разобрался сам, спасибо за помощь!
vxg
Модератор
 Аватар для vxg
2740 / 1751 / 176
Регистрация: 13.01.2012
Сообщений: 6,546
09.09.2016, 09:23     Ошибка дешифровки AES в Android: pad block corrupted #3
Dimarzio, учитывая что аналогичные "трудности" могут испытывать другие разработчика с вашей стороны было бы великим делом оставить в своей теме правильное решение
Dimarzio
5 / 0 / 0
Регистрация: 12.08.2016
Сообщений: 3
13.09.2016, 20:21  [ТС]     Ошибка дешифровки AES в Android: pad block corrupted #4
Дело в том , что, Андроид использует другие провайдеры шифрования, в отличии от Windows, и в данном фрагменте:
Java
1
2
SecureRandom sr = SecureRandom.getInstance("SHA1PRNG");
            sr.setSeed(data.getBytes());
генерируется каждый раз новый ключ.
Для решения проблемы нужно выбирать другой алгоритм генерации ключа.
Вот один из вариантов, который я нашел:
Java
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
public static byte[]encrypt(String key, byte[] data, String iv) {
        final byte[]keyBytes=key.getBytes();
        final byte[] ivBytes=iv.getBytes();
        
 
        try {
            byte[] result;
            SecretKeySpec sks=new SecretKeySpec(keyBytes,"AES");
            Cipher c = Cipher.getInstance("AES/CBC/PKCS5Padding");
            c.init(Cipher.ENCRYPT_MODE, sks, new IvParameterSpec(ivBytes));
            result=c.doFinal(data);
            return result;
 
        }
        catch (Exception e){
            System.out.println("Ошибка шифрования! - "+ e);
        }
    return null;
    }
Теперь мой класс выглядит так:
Java
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
public class AES {
    
    public static byte[]encrypt(String key, byte[] data, String iv) {
        final byte[]keyBytes=key.getBytes();
        final byte[] ivBytes=iv.getBytes();
        
 
        try {
            byte[] result;
            SecretKeySpec sks=new SecretKeySpec(keyBytes,"AES");
            Cipher c = Cipher.getInstance("AES/CBC/PKCS5Padding");
            c.init(Cipher.ENCRYPT_MODE, sks, new IvParameterSpec(ivBytes));
            result=c.doFinal(data);
            return result;
 
        }
        catch (Exception e){
            System.out.println("Ошибка шифрования! - "+ e);
        }
    return null;
    }
public static byte[] decrypt (String key, byte[]data, String iv) {
  byte[] result;
  final byte[]keyBytes=key.getBytes();
  final byte[]ivBytes=iv.getBytes();
  
    try {
      SecretKeySpec sks=new SecretKeySpec(keyBytes, "AES");
        Cipher c=Cipher.getInstance("AES/CBC/PKCS5Padding");
      c.init(Cipher.DECRYPT_MODE,sks, new IvParameterSpec(ivBytes));
        result=c.doFinal(data);
        return result;
  }
catch (Exception e) {
System.out.println("Ошибка дешифровки! - "+e);
}
return null;
}
}
Yandex
Объявления
13.09.2016, 20:21     Ошибка дешифровки AES в Android: pad block corrupted
Ответ Создать тему

Метки
aes, android, java
Опции темы

Текущее время: 05:51. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru