Форум программистов, компьютерный форум, киберфорум
Криптография
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.56/25: Рейтинг темы: голосов - 25, средняя оценка - 4.56
1 / 1 / 0
Регистрация: 21.06.2018
Сообщений: 50

Криптосистема Рабина. проблемы с дешифровкой

11.05.2019, 09:17. Показов 4709. Ответов 3
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
пытаюсь реализовать шифрование Рабина. нашёл алгоритм но при дешифровки ни один из вариантов не является верным.
вот код на python:
Python
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
p = 11
q = 7
n = p * q
 
m = 20
 
c = pow(m, 2) % n
 
m1 = pow(c, (p + 1)/4) % p
m2 = -pow(c, (p + 1)/4) % p
m3 = pow(c, (q + 1)/4) % q
m4 = -pow(c, (q + 1)/4) % q
 
a = q * (pow(q, -1) % p)
b = p * (pow(p, -1) % q)
 
M1 = (a * m4 + b * m3) % n
M2 = (a * m1 + b * m4) % n
M3 = (a * m2 + b * m3) % n
M4 = (a * m2 + b * m4) % n
 
print(M1, M2, M3, M4)
выводит:
7.0 15.0 3.0 8.0
должен вывести:
64 20 13 57
в чём может быть проблема?

p.s меня настораживает a = q(q-1 (mod p)) так как всегда равен 1.
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
11.05.2019, 09:17
Ответы с готовыми решениями:

Криптосистема Рабина
Добрый день. Есть такое задание: 46386527 58147037 25976055 76960311 68173633 55142314 06949797 зашифрован алгоритмом Рабина. n=82500361,...

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

Криптосистема RSA
Каким образом можно организовать передачу шифрованных сообщений с помощью криптосистемы RSA? Приведите примеры. Каким образом с...

3
Фрилансер
 Аватар для Black Fregat
3709 / 2083 / 567
Регистрация: 31.05.2009
Сообщений: 6,683
11.05.2019, 09:59
Цитата Сообщение от Murloc_Knight Посмотреть сообщение
в чём может быть проблема?
Вы не вполне понимаете операции в конечных полях.
В алгоритме стоит инверсия по простому модулю, а Вы реализете её как pow(q, -1) % p, что совсем не одно и то же

Добавлено через 3 минуты
Плюс при делении на 4 нужно использовать целочисленное деление: //

Добавлено через 2 минуты
Вот исправленный код:
Python
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
p = 11
q = 7
n = p * q
 
m = 20
 
c = pow(m, 2) % n
 
m1 = pow(c, (p + 1)//4, p)
m2 = -pow(c, (p + 1)//4, p)
m3 = pow(c, (q + 1)//4, q)
m4 = -pow(c, (q + 1)//4, q)
 
a = q * pow(q, p-2, p)
b = p * pow(p, q-2, q)
 
M1 = (a * m1 + b * m3) % n
M2 = (a * m1 + b * m4) % n
M3 = (a * m2 + b * m3) % n
M4 = (a * m2 + b * m4) % n
 
print(M1, M2, M3, M4)
Добавлено через 3 минуты
Он выдаёт, как и ожидалось
Code
1
64 20 57 13
0
1 / 1 / 0
Регистрация: 21.06.2018
Сообщений: 50
11.05.2019, 15:57  [ТС]
спасибо. но он всё равно в приблизительно 35% случаев выдаёт неверный ответ.
0
Фрилансер
 Аватар для Black Fregat
3709 / 2083 / 567
Регистрация: 31.05.2009
Сообщений: 6,683
12.05.2019, 02:19
Цитата Сообщение от Murloc_Knight Посмотреть сообщение
всё равно в приблизительно 35% случаев выдаёт неверный ответ.
Вероятно, слишком маленькие p и q
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
12.05.2019, 02:19
Помогаю со студенческими работами здесь

RSA криптосистема
Подскажите , пожалуйста, несколько моментов в RSA. 1. Берём m, e, d, n такие, что (me)d = m(mod n). 2. Отправляем на открытый доступ e,...

Криптосистема Рабина: исправить код
Помогите найти ошибку пжл, не правильно работает дешифрование в криптосистеме Рабина. using System; using...

Криптосистема Рабина: нужны примеры реализации
Здравствуйте! прошу помочь найти готовую программу по криптосистеме Рабина. если не сложно, поделитесь пожулайста своей программкой, очень...

Работа с шифровкой\дешифровкой данных ( RSA )
Пытаюсь реализовать для своей проги(хранения текстовых документов) цифровую подпись. Пользуюсь RSA, нашел кучу материалов, столкнулся с...

Криптосистема
Нужно написать криптосистему, используя шифр TEA, алгоритм цепочек cfb, хэширование пароля на основе md5. Также добавить возможность...


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

Или воспользуйтесь поиском по форуму:
4
Ответ Создать тему
Новые блоги и статьи
Оттенки серого
Argus19 18.03.2026
Оттенки серого Нашёл в интернете 3 прекрасных модуля: Модуль класса открытия диалога открытия/ сохранения файла на Win32 API; Модуль класса быстрого перекодирования цветного изображения в оттенки. . .
SDL3 для Desktop (MinGW): Рисуем цветные прямоугольники с помощью рисовальщика SDL3 на Си и C++
8Observer8 17.03.2026
Содержание блога Финальные проекты на Си и на C++: finish-rectangles-sdl3-c. zip finish-rectangles-sdl3-cpp. zip
Символические и жёсткие ссылки в Linux.
algri14 15.03.2026
Существует два типа ссылок — символические и жёсткие. Ссылка в Linux — это запись в каталоге, которая может указывать либо на inode «файла-ИСТОЧНИКА», тогда это будет «жёсткая ссылка» (hard link),. . .
[Owen Logic] Поддержание уровня воды в резервуаре количеством включённых насосов: моделирование и выбор регулятора
ФедосеевПавел 14.03.2026
Поддержание уровня воды в резервуаре количеством включённых насосов: моделирование и выбор регулятора ВВЕДЕНИЕ Выполняя задание на управление насосной группой заполнения резервуара,. . .
делаю науч статью по влиянию грибов на сукцессию
anaschu 13.03.2026
прикрепляю статью
SDL3 для Desktop (MinGW): Создаём пустое окно с нуля для 2D-графики на SDL3, Си и C++
8Observer8 10.03.2026
Содержание блога Финальные проекты на Си и на C++: hello-sdl3-c. zip hello-sdl3-cpp. zip Результат:
Установка CMake и MinGW 13.1 для сборки С и C++ приложений из консоли и из Qt Creator в EXE
8Observer8 10.03.2026
Содержание блога MinGW - это коллекция инструментов для сборки приложений в EXE. CMake - это система сборки приложений. Здесь описаны базовые шаги для старта программирования с помощью CMake и. . .
Как дизайн сайта влияет на конверсию: 7 решений, которые реально повышают заявки
Neotwalker 08.03.2026
Многие до сих пор воспринимают дизайн сайта как “красивую оболочку”. На практике всё иначе: дизайн напрямую влияет на то, оставит человек заявку или уйдёт через несколько секунд. Даже если у вас. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru