LUC

Эта статья находится на начальном уровне проработки, в одной из её версий выборочно используется текст из источника, распространяемого под свободной лицензией
Материал из энциклопедии Руниверсалис

LUC — криптосистема с открытым ключом, разработанная исследователем из Новой Зеландии — Питером Смитом. Так же как RSA, эта система поддерживает шифрование и цифровую подпись. Отличительной чертой системы является использование последовательностей Люка(Lucas) вместо возведения в степень[1].

Описание алгоритма

Введение

Как уже упоминалось ранее, в системе LUC используются последовательности Люка. Они задаются следующими рекурентными соотношениями:

Un+2(P,Q)=PUn+1(P,Q)QUn(P,Q),n0(1.1)
Vn+2(P,Q)=PVn+1(P,Q)QVn(P,Q),n0(1.2)
U0(P,Q)=0,U1(P,Q)=1
V0(P,Q)=2,V1(P,Q)=P
Где P,Q — целые неотрицательные числа.

В основном используется последовательность Vn(P,Q). Поэтому далее будем рассматривать только её. Однако все сформулированные свойства будут справедливы и для Un(P,Q).

Пример последовательностей Люка для P = 3, Q = 1
n Vn(3,1) Un(3,1)
0 2 0
1 3 1
2 7 3
3 18 8
4 47 21
5 123 55
6 322 144
7 843 377
8 2207 987
9 5778 2584
10 15127 6765
11 39603 17711
12 103682 46368
13 271443 121393
14 710647 317811
15 1860498 832040
16 4870847 2178309
17 12752043 5702887
18 33385282 14930352
19 87403803 39088169
20 228826127 102334155
21 599074578 267914296
22 1568397607 701408733
23 4106118243 1836311903
24 10749957122 4807526976

Из таблицы видно, что элементы последовательностей Люка растут очень быстро. Поэтому использовать их в виде (1.1) затруднительно. Эту проблему решает следующее свойство:

  • Vn(PmodN,QmodN)=Vn(P,Q)modNN>2(1.3)

Так же используется ещё одно важное утверждение:

  • Vn(Vk(P,Q),Qk)=Vnk(P,Q)(1.4)

Использование последовательностей Люка в криптографии

Допустим, что существуют такие e и d , что

Vde(X,1)=XmodN

Тогда из (1.3):

Vde(XmodN,1)=Vde(X,1)modN=XmodN

А из (1.4):

Vde(XmodN,1)=Vd(Ve(XmodN,1),1)=XmodN

Сначала от символьного сообщения берётся хеш-функция, которая возвращает цифровое значение X. В качестве функции шифрования используется:

Y=Ve(XmodN,1)

А для дешифрования:

Vd(YmodN,1)=XmodN

В этом алгоритме шифрования открытым ключом будет являться пара {e,N}, а закрытым {d,N}.

Генерация ключа

  • Сначала выбираются два простых числа p и q.
  • Вычисляется их произведение N=pq
  • Выбирается число e, взаимнопростое с числом (p-1)(q-1)(p+1)(q+1):
gcd[(p1)(q1)(p+1)(q+1),e]=1
  • Вычисляется D:
D=P24,
где P — наше сообщение
S(N)=lcm[(p(Dp)),(q(Dq))]
  • Вычисляется d
d=e1modS(N)
  • открытый ключ:
KU=(e,N)
  • закрытый ключ:
KR=(d,N)

Шифрование и дешифрование сообщения

1) Шифрование сообщения P, при условии P < N :

C=Ve(P,1)modN

2) Дешифрование сообщения:

P=Vd(C,1)modN

Пример

Рассмотрим криптосистему LUC на конкретном примере:

1) Выбираем два простых числа:
p=1949,q=2089
2) Вычисляем N:
N=pq=4071461
3) Вычисляем открытый ключ e из уравнения gcd[(p1)(p+1)(q1)(q+1),e]=1 :
gcd[1948208819502090,e]=1=>e=1103
4) Шифровать будем следующее сообщение P = 11111, далее вычисляем символ Лежандра (Dp) :
  • параметр D:
D2=P24=123454317
(Dp)=1
(Dq)=1
5) Теперь вычисляем функцию S(N):
S(N)=lcm[(1949+1),(2089+1)]=407550
6) Закрытый ключ:
d=e1mod407550=24017
7) Зашифрованное сообщение:
C=V1103(11111,1)mod4071461=3975392
8)Дешифрованное сообщение:
P=V24017(3975392,1)mod4071461=11111

Некоторые сложности

При использовании криптосистемы LUC возникают некоторые вычислительные трудности.

  • Во-первых, вычисление больших чисел Люка может оказаться довольно сложной задачей, так как они задаются рекурентно, а следовательно придётся перебрать все предыдуще числа. Однако, эту проблему решают следующие свойства последовательностей Люка:
V2n(P,Q)=[Vn(P,Q)]22Qn
Vn+m(P,Q)=Vn(P,Q)Vm(P,Q)QnVnm
Используя эти свойства можно довольно быстро получить нужное число, раскладывая номер элемента последовательности по степеням двойки. Этот алгоритм аналогичен алгоритму быстрого возведения в степень, который используется в криптосистеме RSA.
  • Во-вторых, приватный ключ d зависит от исходного сообщения P.
Для каждого e существует четыре возможных значений функции S(N):
lcm[(p+1),(q+1)]
lcm[(p+1),(q1)]
lcm[(p1),(q+1)]
lcm[(p1),(q1)]
И следовательно существует четыре возможных значений закрытого ключа d:
d=e1mod(lcm[(p+1),(q+1)])
d=e1mod(lcm[(p+1),(q1)])
d=e1mod(lcm[(p1),(q+1)])
d=e1mod(lcm[(p1),(q1)])
Получая сообщение С, зашифрованное открытым ключом e, первым делом считаем символы Лежандра:
(C24p),(C24q)
По их значениям определяем какой из четырёх закрытых ключей d нужно использовать для дешифровки.

Корректность схемы LUC

Для доказательства необходимо проверить следующее равенство:

Vd[Ve(P,1),1]=P, где
d=e1modS(N),gcd[(p1)(p+1)(q1)(q+1),e]=1,N=pq

Сначала сформулируем две леммы.

  • 2QVnm(P,Q)=Vn(P,Q)Vm(P,Q)DUn(P,Q)Um(P,Q)
  • Для простых p,q, N=pq, S(N) и любых целых k верно:
UkS(N)(P,1)=0modN
VkS(N)(P,1)=2modN
Оставим эту лемму без доказательства[2].

Используя эти две леммы, определение последовательностей Люка и (1.4) получаем:

из уравнения (1.4)
Vd(Ve(P,1),1)=Vde(P,1)
по определению e и d:
=VkS(N)+1(P,1)
по определению (1.2), полагая что Q = 1:
=PVkS(N)(P,1)VkS(N)1(P,1)
из леммы 1:
=PVkS(N)(P,1)12[VkS(N)(P,1)V1(P,1)DUkS(N)(P,1)U1(P,1)]
так как V1(P,1)=P,U1(P,1)=1
=PVkS(N)(P,1)12[PVkS(N)(P,1)DUkS(N)(P,1)]

из Леммы 2:

=2P12[2P0]=PmodN

То есть верно равенство: Vd(Ve(P,1),1)=P

Алгоритм LUCDIF

Алгоритм LUCDIF является комбинацией алгоритма LUC и протокола Диффи-Хеллмана. Основным назначением этого алгоритма является разделение двумя сторонами общего секретного ключа. Реализуется это следующим образом:

  • Сначала Алиса выбирает простое число p, число g, такое что g < p и какое-то секретное число a.
  • Затем Алиса вычисляет число:
Va(g,1)modp
  • После этого Алиса отправляет Бобу сообщение
(Va(g,1)modp,p,g)
  • Боб выбирает своё секретное число b. Используя его, он во-первых, получает общий секретный ключ:
Vb(Va(g,1))modp
  • И затем отправляет Алисе сообщение:
Vb(g,1)modp
  • Алиса, в свою очередь, тоже вычисляет общий секретный ключ:
Va(Vb(g,1))modp

Из свойств последовательностей Люка, следует, что выражения полученные в конечном итоге Алисой и Бобом будут равны. Следовательно, Алиса и Боб будут иметь общий секретный ключ[3].

Алгоритм LUCELG

Алгоритм LUCELG строится на Схеме Эль-Гамаля и последовательностях Люка. Схема Эль-Гамаля используется для шифрования/расшифрования и генерации цифровой подписи. Рассмотрим работу этого алгоритма при шифровании сообщения.

1) Генерация пары открытого и закрытого ключа:

  • Выбираем простое число P
  • Затем выбираем λ такое, что для любых t>1 и делящих (p+1) верно:
Vp+1t(λ,1)2modp
  • Выбираем случайное число x, которое и будет секретным ключом.
  • Вычисляем открытый ключ следующим образом:
y=Vx(λ,1)modp

2) Шифрование сообщения:

  • Сначала выбирается случайное число k, такое что 1 ≤ k ≤ p — 1.
  • После этого, используя открытый ключ y, вычисляется параметр G:
G=Vk(y,1)modp
  • Первая часть криптограммы:
d1=Vk(λ,1)modp
  • Вторая часть:
d2=GMmodp

3) Дешифровка сообщения:

  • Используя закрытый ключ вычисляется G:
G=Vx(d1,1)modp
  • Далее, получая обратный элемент к G по модулю p, получаем исходное сообщение:
M=d2(G1)modp

Примечания

  1. Peter Smith. Luc Public-Key Encryption // Dr. Dobb's journal. — January 1993. Архивировано 11 ноября 2014 года.
  2. Paulo Ribenboim. The little book of bigger primes. — Springer-Verlag New York. — 2004.
  3. Peter Smith. Cryptography Without Exponentiation // Dr. Dobb's journal. — April 01, 1994. Архивировано 7 августа 2016 года.

Литература

  • William Stallings, Network and Internetwork Security Principles and Practice, 1995 — ISBN 0-02-415438-0.
  • Peter Smith, LUC Public-Key Encryption : Dr. Dobb’s journal Jan 1993 pp.44-49.
  • Брюс Шнайер, Прикладная криптография. Протоколы, алгоритмы, исходные тексты на языке Си, 2000 — М : Триумф, 2002. — 816 с. — 3000 экз. — ISBN 5-89392-055-4.
  • Daniel Bleichenbache, Wieb Bosma, Arjen K.Lenstra, Some Remarks on Lucas-Based Cryptosystems