1 / 1 / 0
Регистрация: 21.10.2016
Сообщений: 29

Как перевести из .NET XML в PublicKey (Java), алгоритм RSA?

19.05.2017, 17:02. Показов 1248. Ответов 0

Студворк — интернет-сервис помощи студентам
Здравствуйте!
Делаю связку проектов C# и Android, приложения обмениваются сообщениями по сети и эти сообщения должны быть зашифрованы. Перед началом обмена сообщениями приложения передают друг другу публичные ключи, но тут проблема, Java передает ключ и вроде как C# его принимает и шифрует им, но когда передаю ключ с C# не знаю как из XML перевести в PublicKey.

Перевод из PublicKey в XML (вроде работает):
Java
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
static String getPublicKeyAsXml(PublicKey publicKey){
        try { // Получаем публичный ключ в формате XML ---> отправляем .NET серверу
            KeyFactory kf = KeyFactory.getInstance(EncryptionRSA.ALGORITHM);
            RSAPublicKeySpec ks = kf.getKeySpec(publicKey, RSAPublicKeySpec.class);
            BigInteger modulus = ks.getModulus();
            BigInteger exponent = ks.getPublicExponent();
            byte[] modByte = modulus.toByteArray();
            byte[] expByte = exponent.toByteArray();
            String encodedModulus = Base64.encodeToString(modByte, Base64.NO_WRAP);
            String encodedExponent = Base64.encodeToString(expByte, Base64.NO_WRAP);
            return "<RSAKeyValue>" +
                    "<Modulus>" + encodedModulus + "</Modulus>" +
                    "<Exponent>" + encodedExponent + "</Exponent>" +
                    "</RSAKeyValue>";
        } catch (Exception ex){
            Log.e("Get publicKey as XML",
                    "Error: " + ex.getMessage());
            return null;
        }
    }
Перевод из XML в PublicKey (не работает, ошибка: "bad base-64"):
Java
1
2
3
4
5
6
7
8
9
10
11
12
13
static void setPublicKeyServer(String keyServer){ // Устанавливаем ключ полученный от сервера
        try { // Если ключ не пустой, то пытаемся записать его
            if (!keyServer.isEmpty()){ // Переводим из String в PublicKey
                byte[] keyBytes = Base64.decode(keyServer, Base64.NO_WRAP);
                X509EncodedKeySpec spec = new X509EncodedKeySpec(keyBytes);
                KeyFactory keyFactory = KeyFactory.getInstance(EncryptionRSA.ALGORITHM);
                publicKeyServer = keyFactory.generatePublic(spec);
            } else throw new Exception("String is empty"); // Сообщаем - ключ пустой
        } catch (Exception ex){
            Log.e("Set public key (server)",
                    "Error: " + ex.getMessage());
        }
    }
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
19.05.2017, 17:02
Ответы с готовыми решениями:

Алгоритм RSA на JAVA шифровка/дешифровка
Доброе время суток, форумчане! На днях выдали лабораторное задание, которое сказали реализовать на джаве, с которым я знакома пару недель!...

Ошибка Exception in thread "main" java.lang.ArrayIndexOutOfBoundsException: 0 at pr4.RSA.main(RSA.java:44)
package pr4; import java.math.BigInteger; import java.security.SecureRandom; public class RSA { private final...

Перевести алгоритм на java
Помогите перевести данный алгоритм с с++ на джаву, с++ совсем не знаю, не могу разобраться в этом: #ifndef SCG_CC_ #define...

0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
19.05.2017, 17:02
Помогаю со студенческими работами здесь

Перевести код с Java (отправка XML через сокет)
Доброго времени суток. Очень нужно перевести на VB .Net с Java import java.net.*; import java.io.*; public class sendxml { ...

Работа с Excel средствами VB.net. Как перевести код из VBA в VB.net?
Коллеги, добрый день! Нужна помощь! В свое время был написан макрос для Excel, но прошло и потребности выросли. Было принято...

Запись звука в .NET - как перевести на vb.net c языка C++
Можно ли этот код: Запись звука в .NET перевести на vb.net ? Может кто-то уже переводил или писал что то на vb.net? Добавлено через 7...


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

Или воспользуйтесь поиском по форуму:
1
Ответ Создать тему
Опции темы

Новые блоги и статьи
Валидация и контроль данных табличной части документа перед записью
Maks 22.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа, разработанного в КА2. Задача: контроль и валидация данных табличной части документа перед записью с учетом регламента компании. . .
Отчёт о затраченных материалах за определенный период с макетом печатной формы
Maks 21.04.2026
Отчёт из решения ниже размещён в конфигурации КА2. Задача: разработка отчёта по затраченным материалам за определённый период, с возможностью вывода печатной формы отчёта с шапкой и подвалом. В. . .
Отчёт о спецтехнике находящейся в ремонте
Maks 20.04.2026
Отчёт из решения ниже размещен в конфигурации КА2. Задача: отобразить спецтехнику, которая на данный момент находится в ремонте. Есть нетиповой документ "Заявка на ремонт спецтехники" который. . .
Памятка для бота и "визитка" для читателей "Semantic Universe Layer (Слой семантической вселенной)"
Hrethgir 19.04.2026
Сгенерировано для краткого описания по случаю сборки и компиляции скелета серверного приложения. И пусть после этого скажут, что статьи сгенерированные AI - туфта и не интересно. И это не реклама -. . .
Запрет удаления строк ТЧ документа при определённом условии
Maks 19.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "Аккумуляторы", разработанного в конфигурации КА2. У данного документа есть ТЧ, в которой в зависимости от прав доступа. . .
Модель заражения группы наркоманов
alhaos 17.04.2026
Условия задачи сформулированы тут Суть: - Группа наркоманов из 10 человек. - Только один инфицирован ВИЧ. - Колются одной иглой. - Колются раз в день. - Колются последовательно через. . .
Мысли в слух. Про "навсегда".
kumehtar 16.04.2026
Подумалось тут, что наверное очень глупо использовать во всяких своих установках понятие "навсегда". Это очень сильное понятие, и я только начинаю понимать край его смысла, не смотря на то что давно. . .
My Business CRM
MaGz GoLd 16.04.2026
Всем привет, недавно возникла потребность создать CRM, для личных нужд. Собственно программа предоставляет из себя базу данных клиентов, в которой можно фиксировать звонки, стадии сделки, а также. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru