![]() |
Модераторы: javastic, AntonSaburov |
![]() ![]() ![]() |
|
dartx |
|
|||
Новичок Профиль Группа: Участник Сообщений: 41 Регистрация: 6.4.2006 Репутация: нет Всего: нет |
Суть вопроса такова. Я шифрую данные с помощью AES (bouncy castle) и пытаюсь отослать на сервер написанный на .net, там я пытаюсь их расшифровать, но неполучается, исключения чтото там с padding неправильным. Пулычаемый зашифрованные массив в j2me signed byte (в java нет беззнаковых), а .net ожидает беззнаковый, думаю из-за этого траблы. Не знаете как обойти это?
|
|||
|
||||
VOS |
|
|||
Шустрый ![]() Профиль Группа: Участник Сообщений: 145 Регистрация: 31.1.2007 Репутация: 6 Всего: 8 |
Сделайте преобразование типа unsigned char* tmp=(unsigned char*) data; (С++)
И работайте с беззнаковым вариантом. Данные-то одни и те же, разница лишь в том, как интерпретировать 1 бит. Это может повлиять при дальнейшей обработке данных, например при сдвигах, которые активно используются в алгоритмах шифрования. Вопрос чем заполнять сдвинутые биты нулями или единицами. В Java есть для этого >>> (чтобы 1 заполнялись), а например в C++ другой механизм. Помимо этого, если у Вас русские буквы передаются, то на сервере кодировка скорее всего другая, поэтому для отладки сначала передавайте англ и цифры, а потом, когда убедитесь, что все ок передается/расшифровывается занимайтесь проблемой кодировок (utf-8 или свой перекодировщик и т.д.) Надеюсь это не OFF TOPIC. |
|||
|
||||
dartx |
|
|||
Новичок Профиль Группа: Участник Сообщений: 41 Регистрация: 6.4.2006 Репутация: нет Всего: нет |
я использую c# и стандартные алгоритмы .net для шифрования, а метод для расшифровки принимает только byte (unsigned)
Это сообщение отредактировал(а) dartx - 5.10.2007, 09:30 |
|||
|
||||
VOS |
|
|||
Шустрый ![]() Профиль Группа: Участник Сообщений: 145 Регистрация: 31.1.2007 Репутация: 6 Всего: 8 |
Че-то я проблемы не вижу. Как выполнять преобразования в C# обратитесь лучше в соответствующий форум. Тут это
![]() |
|||
|
||||
dartx |
|
|||
Новичок Профиль Группа: Участник Сообщений: 41 Регистрация: 6.4.2006 Репутация: нет Всего: нет |
Ну да, а там мне скажут офтопик, идите в java форум.
|
|||
|
||||
VOS |
|
|||
Шустрый ![]() Профиль Группа: Участник Сообщений: 145 Регистрация: 31.1.2007 Репутация: 6 Всего: 8 |
Это смотря как вопрос задать
![]() Можно вот еще что попробовать. Насколько я помню AES - это симметричное шифрование. Зашифруйте те же данные в .net тем же ключом. Конечно без синхропосылок (я не знаком с AES, может он и не юзает их). И сравните результат с тем, что в J2me. |
|||
|
||||
![]() ![]() ![]() |
FAQ раздела лежит здесь! |
0 Пользователей читают эту тему (0 Гостей и 0 Скрытых Пользователей) | |
0 Пользователей: | |
« Предыдущая тема | Java ME (J2ME) | Следующая тема » |
|
По вопросам размещения рекламы пишите на vladimir(sobaka)vingrad.ru
Отказ от ответственности Powered by Invision Power Board(R) 1.3 © 2003 IPS, Inc. |