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

Алгоритм ЭЦП на основе сложности дискретного логарифмирования

11.06.2017, 13:27. Показов 3513. Ответов 5
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Возникла следующая проблема, есть определенные формулы для расчета, но при повторении расчета по этим формулам получаются совершенно иные значения.

Подскажите как необходимо высчитывать значения k и g, чтобы получать значения, аналогичные представленным в примере.
Скриншот примера -


Учебник - Молдовян, Практикум по криптосистемам с открытым ключом
0
Лучшие ответы (1)
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
11.06.2017, 13:27
Ответы с готовыми решениями:

ЭЦП на основе сложного дискретного логарифмирования С++
Задание вложено. Реализовал с помощью либы GMP: //Расчитываем открытый ключ y void _y_open_key(mpz_t y, mpz_t a, mpz_t x, mpz_t p) { ...

ЭЦП со сложностью дискретного логарифмирования. Непонятный параметр q. Молдовян
Реализовал схему с проверочным уравнением {a}^{k}{y}^{H(S{a}^{k}mod p)}\equiv S mod p, где {a}^{\gamma }\equiv modp, S\equiv...

ро-метод Полларда дискретного логарифмирования
Добрый день. Задача: Элемент a имеет порядок q по модулю p. Найти дискретный логарифм x - такое целое число 1<x<q, что a^x = b...

5
Эксперт С++
 Аватар для grizlik78
2382 / 1666 / 279
Регистрация: 29.05.2011
Сообщений: 3,402
12.06.2017, 21:56
Лучший ответ Сообщение было отмечено andrewromanov как решение

Решение

Формулы для k и g перепутаны, но значения правильные.
Вот программка на python, выполняющая эти вычисления:
Python
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
from __future__ import print_function
 
p = 1188242948802635102242772106637989280357
a = 682502200821353544223897742429626534895
gamma = 187266130527359358103409790533
delta = 1000000000000000003
x = 12345678900987654321
 
y = pow(a, x, p)
print('y =', y)
H = 11223344556677889900
U = 13894564231549754238457865456
Z = pow(a, U, p)
print('Z =', Z)
d = (1 + gamma) // 2
k = ((U + x*Z + (H*Z) % delta) * d) % gamma
g = ((U - x*Z - (H*Z) % delta) * d) % gamma
print('k =', k)
print('g =', g)
S = pow(a, g, p)
print('S =', S)
результат работы:
Code
1
2
3
4
5
y = 515195030626449857135211347072944115270
Z = 647016984661564319416569408164688002775
k = 68742013608792151040356901280
g = 132418681150116961301510754709
S = 2512740207764180842719228564280308315
1
0 / 0 / 0
Регистрация: 07.10.2014
Сообщений: 62
13.06.2017, 10:00  [ТС]
Цитата Сообщение от grizlik78 Посмотреть сообщение
Формулы для k и g перепутаны, но значения правильные.
Вот программка на python, выполняющая эти вычисления:
Python
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
from __future__ import print_function
 
p = 1188242948802635102242772106637989280357
a = 682502200821353544223897742429626534895
gamma = 187266130527359358103409790533
delta = 1000000000000000003
x = 12345678900987654321
 
y = pow(a, x, p)
print('y =', y)
H = 11223344556677889900
U = 13894564231549754238457865456
Z = pow(a, U, p)
print('Z =', Z)
d = (1 + gamma) // 2
k = ((U + x*Z + (H*Z) % delta) * d) % gamma
g = ((U - x*Z - (H*Z) % delta) * d) % gamma
print('k =', k)
print('g =', g)
S = pow(a, g, p)
print('S =', S)
результат работы:
Code
1
2
3
4
5
y = 515195030626449857135211347072944115270
Z = 647016984661564319416569408164688002775
k = 68742013608792151040356901280
g = 132418681150116961301510754709
S = 2512740207764180842719228564280308315
А с проверкой подписи получается тоже что-то не так?
Python
1
2
compare1 = (S * y^((a^k * S) % p) * a^(((H * ((a^k * S) % p))) % delta)) % p
compare2 = a ^ k;
compare1 = 750481722866102561102226893656246942165
compare2 = 682502200845519936091824910284307720783
0
Эксперт С++
 Аватар для grizlik78
2382 / 1666 / 279
Регистрация: 29.05.2011
Сообщений: 3,402
13.06.2017, 10:42
Да, не так. Во-первых оператор ^ в python это не возведение степень. Возведение в степень обозначается **, но с большими числами это работать не будет. Для нахождения степени по модулю есть более эффективный алгоритм, который реализован в функции pow с тремя аргументами.
Правильно будет как-то так:
Python
1
2
3
akS = pow(a, k, p) * S % p
compare1 = (S * pow(y, akS, p) * pow(a, H * akS % delta, p)) % p
compare2 = pow(a, k, p)
1
0 / 0 / 0
Регистрация: 07.10.2014
Сообщений: 62
14.06.2017, 11:03  [ТС]
grizlik78, а можете еще подсказать, как будет правильно в таком случае?
[IMG]http://i.**********/3CZ7HT5.png[/IMG]
Python
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
p = 1188242948802635102242772106637989280357
a = 682502200821353544223897742429626534895
gamma = 187266130527359358103409790533
delta = 1000000000000000003
x = 12345678900987654321
 
y = pow(a, x, p)
print('y =', y)
H = 11223344556677889900
U = 13894564231549754238457865456
Z = pow(a, U, p)
print('Z =', Z)
#k = ((U + x*Z + (H*Z) % delta) * d) % gamma
#g = ((U - x*Z - (H*Z) % delta) * d) % gamma
 
d = (1 + gamma) // x
k = ((Z - U) * d) % gamma
d = (1 + gamma) // (Z - U)
g = ((U * x) * d) % gamma
 
print('k =', k)
print('g =', g)
S = pow(a, g, p)
print('S =', S)
 
#akS = pow(a, k, p) * S % p
#compare1 = (S * pow(y, akS, p) * pow(a, H * akS % delta, p)) % p
#compare2 = pow(a, k, p)
compare1 = pow(S*y, k, p)
compare2 = pow(a, pow(S, k, p), p)
 
print('compare1 =', compare1)
print('compare2 =', compare2)
y = 515195030626449857135211347072944115270
Z = 647016984661564319416569408164688002775
k = 69723436066911832210851543645
g = 0
S = 1
compare1 = 617813055556188823797630213346059079690
compare2 = 682502200821353544223897742429626534895
0
Эксперт С++
 Аватар для grizlik78
2382 / 1666 / 279
Регистрация: 29.05.2011
Сообщений: 3,402
14.06.2017, 15:28
Да, нужно было, конечно пояснить. Деление на число по модулю заменяется умножением на мультипликативно-обратный элемент, то есть на такое число, которое при умножение на исходное даёт единицу в результате приведения по модулю. Формула, которую я использовал, справедлива только для двойки. В общем случае обратный элемент можно найти с помощью расширенного алгоритма Евклида. Готовую реализацию можно взять, например, из модуля gmpy2.
Python
1
2
3
4
5
6
from gmpy2 import invert
 
d = int(invert(x, gamma))
k = ((Z - U) * d) % gamma
d = int(invert(Z - U, gamma))
g = ((U * x) * d) % gamma
1
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
14.06.2017, 15:28
Помогаю со студенческими работами здесь

Нужен алгоритм проверки сложности пароля
подскажите пожалуйста что исправить в коде чтобы он выполнял все условия 1. пароль должен быть длинее 3 символов 2. содержать не менее...

Существует ли алгоритм или программа создания Sudoku с разными степенями сложности
Существует ли алгоритм или программа создания Sudoku с разными степенями сложности в VB.NET или в VB6?

Вычисление НОД двух чисел методом последовательного перебора (Алгоритм, анализ, сложности)
Вычисление НОД двух чисел m и n методом последовательного перебора. Шаг 1. Присвоить значение функции min переменной t; Шаг 2....

Алгоритм на основе задачи о рюкзаке, усложненный
Здравствуйте. Необходимо написать алгоритм следующей задачи: Есть рюкзак с определенной вместимостью. Есть несколько блоков данных, в...

Архиватор , в основе которого будет лежать алгоритм Хаффмана
Итак, приветствую всех=) случилась у меня беда, дали вот такую весёлую" тему для курсача =)(не спрашивайте почему не выбрал другую, как и...


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

Или воспользуйтесь поиском по форуму:
6
Ответ Создать тему
Новые блоги и статьи
Управление камерой с помощью скрипта OrbitControls.js на Three.js: Вращение, зум и панорамирование
8Observer8 05.03.2026
Содержание блога Финальная демка в браузере работает на Desktop и мобильных браузерах. Итоговый код: orbit-controls-threejs-js. zip. Сканируйте QR-код на мобильном. Вращайте камеру одним пальцем,. . .
SDL3 для Web (WebAssembly): Синхронизация спрайтов SDL3 и тел Box2D
8Observer8 04.03.2026
Содержание блога Финальная демка в браузере. Итоговый код: finish-sync-physics-sprites-sdl3-c. zip На первой гифке отладочные линии отключены, а на второй включены:. . .
SDL3 для Web (WebAssembly): Идентификация объектов на Box2D v3 - использование userData и событий коллизий
8Observer8 02.03.2026
Содержание блога Финальная демка в браузере. Итоговый код: finish-collision-events-sdl3-c. zip Сканируйте QR-код на мобильном и вы увидите, что появится джойстик для управления главным героем. . . .
Реалии
Hrethgir 01.03.2026
Нет, я не закончил до сих пор симулятор. Эта задача сложнее. Не получилось уйти в плавсостав, но оно и к лучшему, возможно. Точнее получалось - но сварщиком в палубную команду, а это значит, в моём. . .
Ритм жизни
kumehtar 27.02.2026
Иногда приходится жить в ритме, где дел становится всё больше, а вовлечения в происходящее — всё меньше. Плотный график не даёт вниманию закрепиться ни на одном событии. Утро начинается с быстрых,. . .
SDL3 для Web (WebAssembly): Сборка библиотек: SDL3, Box2D, FreeType, SDL3_ttf, SDL3_mixer и SDL3_image из исходников с помощью CMake и Emscripten
8Observer8 27.02.2026
Недавно вышла версия 3. 4. 2 библиотеки SDL3. На странице официальной релиза доступны исходники, готовые DLL (для x86, x64, arm64), а также библиотеки для разработки под Android, MinGW и Visual Studio. . . .
SDL3 для Web (WebAssembly): Реализация движения на Box2D v3 - трение и коллизии с повёрнутыми стенами
8Observer8 20.02.2026
Содержание блога Box2D позволяет легко создать главного героя, который не проходит сквозь стены и перемещается с заданным трением о препятствия, которые можно располагать под углом, как верхнее. . .
Конвертировать закладки radiotray-ng в m3u-плейлист
damix 19.02.2026
Это можно сделать скриптом для PowerShell. Использование . \СonvertRadiotrayToM3U. ps1 <path_to_bookmarks. json> Рядом с файлом bookmarks. json появится файл bookmarks. m3u с результатом. # Check if. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru