Интернет магазин китайских планшетных компьютеров



Компьютеры - RSA - Описание алгоритма

29 мая 2011


Оглавление:
1. RSA
2. Описание алгоритма



Введение

Криптографические системы с открытым ключом используют так называемые необратимые функции, которые обладают следующим свойством:

  • Если известно x\,, то f\, вычислить относительно просто
  • Если известно y=f\,, то для вычисления x\, нет простого пути.

Под однонаправленностью понимается не теоретическая однонаправленость, а практическая невозможность вычислить обратное значение, используя современные вычислительные средства, за обозримый интервал времени.

В основу криптографической системы с открытым ключом RSA положена задача умножения и разложения составных чисел на простые сомножители, которая является вычислительно однонаправленной задачей .

В криптографической системе с открытым ключом каждый участник располагает как открытым ключом, так и закрытым ключом. Каждый ключ — это часть информации. В криптографической системе RSA каждый ключ состоит из пары целых чисел. Каждый участник создаёт свой открытый и закрытый ключ самостоятельно. Закрытый ключ каждый из них держит в секрете, а открытые ключи можно сообщать кому угодно или даже публиковать их. Открытый и закрытый ключи каждого участника обмена сообщениями образуют «согласованную пару» в том смысле, что они являются взаимно обратными, т.е

\forall\, сообщения M \in W\,, где W\, — множество допустимых сообщений.
  \forall\, открытого и секретного ключа P\, и S\, 
    \exist\, соответствующие функции шифрования E_p\, и расшифрования D_s:\,  
                     
                               M=D_s)\,
                               M=E_p)\,

Алгоритм создания открытого и секретного ключей

RSA-ключи генерируются следующим образом:

  1. Выбираются два случайных простых числа p и q заданного размера.
  2. Вычисляется их произведение n = pq, которое называется модулем.
  3. Вычисляется значение функции Эйлера от числа n:
    \varphi=.
  4. Выбирается целое число e" src="http://upload.wikimedia.org/math/5/b/8/5b8e85fcd4e4122799d95918630b0264.png" />), взаимно простое со значением функции \varphi. Обычно в качестве e берут простые числа, содержащие небольшое количество единичных битов в двоичной записи, например, простые числа Ферма 17, 257 или 65537.
    • Число e называется открытой экспонентой
    • Время, необходимое для шифрования с использованием быстрого возведения в степень, пропорционально числу единичных бит в e.
    • Слишком малые значения e, например 3, потенциально могут ослабить безопасность схемы RSA.
  5. Вычисляется число d, мультипликативно обратное к числу e по модулю \varphi, то есть число, удовлетворяющее условию:
    d e \equiv  1\pmod{\varphi}, или: de = 1 + k\varphi, где k — некоторое целое число.
    • Примечание: Можно вычислять и так mod*) = 1. Результат операции i mod j — остаток от целочисленного деления i на j, то есть если имеем mod 20 = 1. Значит d будет, например 7..
    • Число d называется секретной экспонентой.
    • Обычно, оно вычисляется при помощи расширенного алгоритма Евклида.
  6. Пара P = публикуется в качестве открытого ключа RSA.
  7. Пара S = играет роль секретного ключа RSA и держится в секрете.

Шифрование и расшифрование

Схема RSA

Предположим, сторона B \, хочет послать стороне A \, сообщение M \,.

Сообщением являются целые числа лежащие от 0 \, до n-1 \,, т.е M \isin D=\mathbb{Z}_{n}\,.

RSA.svg

Алгоритм:

  • Взять открытый ключ  \, стороны A \,
  • Взять открытый текст M \,
  • Передать шифрованное сообщение:

P_A=M^e \mod n~~~~~~~~~~\,

Алгоритм:

  • Принять зашифрованное сообщение C \,
  • Применить свой секретный ключ  \, для расшифровки сообщения:

S_A=C^d \mod n~~~~~~~~~~\,

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

Уравнения \, и \,, на которых основана схема RSA, определяют взаимно обратные преобразования множества \mathbb{Z}_{n}\,


Просмотров: 3597


<<< Purple (шифровальная машина)
RSA-KEM >>>