С Новым годом! Форум программистов, компьютерный форум, киберфорум
C# для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.83/18: Рейтинг темы: голосов - 18, средняя оценка - 4.83
1 / 1 / 0
Регистрация: 21.10.2016
Сообщений: 29

Ошибка при дешифровании, алгоритм RSA

07.05.2017, 17:54. Показов 3849. Ответов 6

Студворк — интернет-сервис помощи студентам
Здравствуйте! Пишу приложения сервер и клиент. В приложениях поставил шифрование RSA, но возникли проблемы при дешифровании, получаю ошибку: "Размер данных для дешифрования превышает максимум для этого модуля, 256 байт.".
Вот код для дешифрования (на вход идут зашифрованные данные (текстовое сообщение), полученные по сети):
C#
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
private static byte[] GetDecryptBytes(byte[] bytes)
        {
            try
            {
                RSACryptoServiceProvider RsaKey = new RSACryptoServiceProvider(2048);
                RsaKey.PersistKeyInCsp = false;
                RsaKey.ImportParameters(privateKey);
                return RsaKey.Decrypt(bytes, true);
            }
            catch (Exception e)
            {
                Console.WriteLine("[{0}] Error: {1}", DateTime.Now.ToString(culture), e.ToString());
                return bytes;
            }
        }
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
07.05.2017, 17:54
Ответы с готовыми решениями:

Ошибка деления на ноль. Алгоритм RSA
Есть в криптографии алгоритм RSA для получения ключей. Есть заготовка программы для реализации этого алгоритма. using System; using...

Ошибка при расшифровке пакета [RSA]
Всем удачного нового года! Столкнулся с проблемой при расшифровке сообщения, закодированного с помощью RSA. Вырезка из RSA.cs:...

Ошибка в работе с RSA при расшифровке данных
вот тут строка зашифровывается нормально public string RSA(string Name) { RSACryptoServiceProvider RsaKey =...

6
Администратор
Эксперт .NET
 Аватар для OwenGlendower
18245 / 14169 / 5366
Регистрация: 17.03.2014
Сообщений: 28,848
Записей в блоге: 1
07.05.2017, 19:12
Edward1426, алгоритм RSA не может шифровать данные произвольного размера. Максимальная длина данных определяется длиной ключа. Для ключа в 208 битов это будет 214 байтов. Судя по исключению быд передан буфер длиной 256 байтов. И раз при шифровании исключения не возникло и речь идет о сети, то похоже зашифрован был допустимый размер данных, принимающая сторона получила данные и передала весь буфер методу дешифровки, а нужно передавать буфер с размером который соответствует размеру зашифрованных данных.
0
1 / 1 / 0
Регистрация: 21.10.2016
Сообщений: 29
08.05.2017, 10:25  [ТС]
Спасибо Вам, что ответили, но я не совсем понял, то есть чтобы передать "большое" сообщение, то нужно увеличить длину ключа?
0
Администратор
Эксперт .NET
 Аватар для OwenGlendower
18245 / 14169 / 5366
Регистрация: 17.03.2014
Сообщений: 28,848
Записей в блоге: 1
08.05.2017, 10:50
Edward1426, да, но в данном случае дело не в этом. По моему ошибка возникает потому что ты пытаешься расшифровать больше данных чем было получено на самом деле. То есть есть буфер длиной 256 байтов в котором нужных байтов меньше. Надо отрезать лишнее и дешифровывать этот массив.
0
1 / 1 / 0
Регистрация: 21.10.2016
Сообщений: 29
08.05.2017, 11:07  [ТС]
Огромное спасибо Вам, в этом и есть ошибка. Могли бы Вы сказать, как можно обрезать этот буфер, если мне известно кол-во принятых. Я пытался через цикл for, но дешифровка происходит неправильно, хоть и прежней ошибки нет.

bytesRead - кол-во принятых байтов
state.buffer - буфер, в который записывается принятые байты (в нем есть и не заполненные байты, которые нужно обрезать)
C#
1
2
3
4
5
6
7
...
byte[] bytes = new byte[bytesRead];
            for (int i = 0; i < bytesRead; i++)
            {
                bytes[i] = state.buffer[i];
            }
...
0
Администратор
Эксперт .NET
 Аватар для OwenGlendower
18245 / 14169 / 5366
Регистрация: 17.03.2014
Сообщений: 28,848
Записей в блоге: 1
08.05.2017, 11:40
Edward1426, обрезание буфера уже сделано верно. Можно было использовать Array.Copy или Buffer.BlockCopy вместо цикла, но это не принципиально.

Цитата Сообщение от Edward1426 Посмотреть сообщение
дешифровка происходит неправильно, хоть и прежней ошибки нет.
Если при дешифровке нет исключения, то проблема уже не в RSA
0
1 / 1 / 0
Регистрация: 21.10.2016
Сообщений: 29
09.05.2017, 05:38  [ТС]
Большое спасибо Вам, я пересмотрел код и исправил одну опечатку. Теперь все работает корректно.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
09.05.2017, 05:38
Помогаю со студенческими работами здесь

Алгоритм RSA
Кто чтото может сказать про алгоритм RSA? У ково есть сам алгоритм RSA? У ково есть хоть на какомто языке RSA? Пажалуста... Я вам...

Алгоритм RSA
Всем привет. Вот пытаюсь изобрести велосипед))) Короче почти все работает, сообщение шифруется, возникла проблема при расшифровке. т.к....

RSA алгоритм
можете объяснить как правильно использовать сие алгоритм в C# с использование встроенных классов. если не сложно, объясните на примере...

Алгоритм шифрования RSA
Здравствуйте. Может кто помочь с написанием кода для шифрования RSA? На словах суть данного шифрования понятна, но вот когда начинаешь...

Алгоритм шифрования RSA
Добрый вечер! Столкнулся со следующей проблемой: Пытаюсь реализовать алгоритм шифрования RSA, нахожу все значения которые нужны для...


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

Или воспользуйтесь поиском по форуму:
7
Ответ Создать тему
Новые блоги и статьи
Модель микоризы: классовый агентный подход
anaschu 02.01.2026
Раньше это было два гриба и бактерия. Теперь три гриба, растение. И на уровне агентов добавится между грибами или бактериями взаимодействий. До того я пробовал подход через многомерные массивы,. . .
Учёным и волонтёрам проекта «Einstein@home» удалось обнаружить четыре гамма-лучевых пульсара в джете Млечного Пути
Programma_Boinc 01.01.2026
Учёным и волонтёрам проекта «Einstein@home» удалось обнаружить четыре гамма-лучевых пульсара в джете Млечного Пути Сочетание глобально распределённой вычислительной мощности и инновационных. . .
Советы по крайней бережливости. Внимание, это ОЧЕНЬ длинный пост.
Programma_Boinc 28.12.2025
Советы по крайней бережливости. Внимание, это ОЧЕНЬ длинный пост. Налог на собак: https:/ / **********/ gallery/ V06K53e Финансовый отчет в Excel: https:/ / **********/ gallery/ bKBkQFf Пост отсюда. . .
Кто-нибудь знает, где можно бесплатно получить настольный компьютер или ноутбук? США.
Programma_Boinc 26.12.2025
Нашел на реддите интересную статью под названием Anyone know where to get a free Desktop or Laptop? Ниже её машинный перевод. После долгих разбирательств я наконец-то вернула себе. . .
Thinkpad X220 Tablet — это лучший бюджетный ноутбук для учёбы, точка.
Programma_Boinc 23.12.2025
Рецензия / Мнение/ Перевод Нашел на реддите интересную статью под названием The Thinkpad X220 Tablet is the best budget school laptop period . Ниже её машинный перевод. Thinkpad X220 Tablet —. . .
PhpStorm 2025.3: WSL Terminal всегда стартует в ~
and_y87 14.12.2025
PhpStorm 2025. 3: WSL Terminal всегда стартует в ~ (home), игнорируя директорию проекта Симптом: После обновления до PhpStorm 2025. 3 встроенный терминал WSL открывается в домашней директории. . .
Как объединить две одинаковые БД Access с разными данными
VikBal 11.12.2025
Помогите пожалуйста !! Как объединить 2 одинаковые БД Access с разными данными.
Новый ноутбук
volvo 07.12.2025
Всем привет. По скидке в "черную пятницу" взял себе новый ноутбук Lenovo ThinkBook 16 G7 на Амазоне: Ryzen 5 7533HS 64 Gb DDR5 1Tb NVMe 16" Full HD Display Win11 Pro
Музыка, написанная Искусственным Интеллектом
volvo 04.12.2025
Всем привет. Некоторое время назад меня заинтересовало, что уже умеет ИИ в плане написания музыки для песен, и, собственно, исполнения этих самых песен. Стихов у нас много, уже вышли 4 книги, еще 3. . .
От async/await к виртуальным потокам в Python
IndentationError 23.11.2025
Армин Ронахер поставил под сомнение async/ await. Создатель Flask заявляет: цветные функции - провал, виртуальные потоки - решение. Не threading-динозавры, а новое поколение лёгких потоков. Откат?. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru