Модераторы: LSD, AntonSaburov
  

Поиск:

Ответ в темуСоздание новой темы Создание опроса
> encrypt/decrypt проблема с кодировкой 
:(
    Опции темы
4epT
Дата 12.3.2012, 12:04 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Опытный
**


Профиль
Группа: Участник
Сообщений: 784
Регистрация: 13.8.2007

Репутация: нет
Всего: 3



Всем привет. Делаю класс CryptoUtil, для шифрования и дешифрования данных. На некоторых данных расшифровка сыпется, насколько я понял то ломается кодировка, так как класс полностью рабочий если после шифрования не преобразовывать массив байт в строку.

Вот собственно код:

Код

public String encode(String cleartext, Key key) {
        try {
            System.out.println(cleartext);
            return new BASE64Encoder().encode(crypt(cleartext.getBytes(Const.ENCODING), key, Cipher.ENCRYPT_MODE));
        } catch (UnsupportedEncodingException e) {
            e.printStackTrace();
        }
        return null;
    }

public String decode(String data, Key key) {
        try {
            System.out.println(data);
            byte[] ciphertext = new BASE64Decoder().decodeBuffer(data);
            return new String(crypt(ciphertext, key, Cipher.DECRYPT_MODE), Const.ENCODING);
        } catch (UnsupportedEncodingException e) {
            e.printStackTrace();
        } catch (IOException ex){
            ex.printStackTrace();
        }
        return null;
    }


private byte[] crypt(byte[] input, Key key, int mode) {
        
        IvParameterSpec iv = new IvParameterSpec(SALT);
        Cipher c;
        try {
            c = Cipher.getInstance(ALGORITHM);
            c.init(mode, key, iv);
            return c.doFinal(input);
        } catch (Exception e) {
            e.printStackTrace();
        }
        return null;
    }


Кодировка везде UTF-8 (Указывется через Const.ENCODING). После шифрования массив байт преобразовывается в стркоу при помощи BASE64Encoder, а при расшифровки строка преобразуется в массив байт при помощи BASE64Decoder. В итоге вылетает исключение:

Код

SEVERE: javax.crypto.IllegalBlockSizeException: Input length must be multiple of 8 when decrypting with padded cipher
    at com.sun.crypto.provider.SunJCE_f.b(DashoA13*..)
    at com.sun.crypto.provider.SunJCE_f.b(DashoA13*..)
    at com.sun.crypto.provider.BlowfishCipher.engineDoFinal(DashoA13*..)


В чем может быть проблема ?
PM MAIL   Вверх
Alexandr87
Дата 13.3.2012, 11:46 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


дыкий псых
***


Профиль
Группа: Завсегдатай
Сообщений: 1459
Регистрация: 27.11.2004
Где: Алматы, Казахстан

Репутация: 9
Всего: 39



Проблема в том, что на вход расшифровывания ожидается размер массива кратный 8. (блочное шифрования), но почему-то подается не кратный 8.

ALGORITHM чему равен?
И приведите следующие данные: размер следующих массивов байт (именно массивов байт до кодирования в BASE64 и после раскодирвоание из BASE64). Шифруемые массив, массив - результат шифрования, массив подаяющийся на вход расшифровывания, массив данных после расшифровывания.


PM Jabber   Вверх
  
Ответ в темуСоздание новой темы Создание опроса
Правила форума "Java"
LSD   AntonSaburov
powerOn   tux
javastic
  • Прежде, чем задать вопрос, прочтите это!
  • Книги по Java собираются здесь.
  • Документация и ресурсы по Java находятся здесь.
  • Используйте теги [code=java][/code] для подсветки кода. Используйтe чекбокс "транслит", если у Вас нет русских шрифтов.
  • Помечайте свой вопрос как решённый, если на него получен ответ. Ссылка "Пометить как решённый" находится над первым постом.
  • Действия модераторов можно обсудить здесь.
  • FAQ раздела лежит здесь.

Если Вам помогли, и атмосфера форума Вам понравилась, то заходите к нам чаще! С уважением, LSD, AntonSaburov, powerOn, tux, javastic.

 
0 Пользователей читают эту тему (0 Гостей и 0 Скрытых Пользователей)
0 Пользователей:
« Предыдущая тема | Java: Общие вопросы | Следующая тема »


 




[ Время генерации скрипта: 0.0522 ]   [ Использовано запросов: 22 ]   [ GZIP включён ]


Реклама на сайте     Информационное спонсорство

 
По вопросам размещения рекламы пишите на vladimir(sobaka)vingrad.ru
Отказ от ответственности     Powered by Invision Power Board(R) 1.3 © 2003  IPS, Inc.