Информационная безопасность. Современные алгоритмы шифрования презентация

Содержание

Слайд 2

Алгоритм RSA Р. Райвест (R. Rivest), А. Шамир (A. Shamir)

Алгоритм RSA

Р. Райвест (R. Rivest), А. Шамир (A. Shamir) и Л. Адлеман (L. Adleman), 1977.

Шифрование с открытым

ключом:

1010100101010101010111

открытый ключ

секретный ключ

связаны!

Идея: применение открытого и секретного ключа восстанавливает сообщение:

1010100101010101010111

открытый ключ

секретный ключ

связаны!

электронная цифровая подпись

Слайд 3

Как построить ключи RSA? Выбрать два простых числа, например, Вычислить

Как построить ключи RSA?

Выбрать два простых числа, например,
Вычислить
Выбрать число e

(1< e < ϕ), которое не имеет общих делителей с ϕ :
Найти число d, для которого при некотором целом k выполняется условие:
Открытый ключ:
Секретный ключ:
Слайд 4

Алгоритм RSA Шифрование: открытый ключ Расшифровка: секретный ключ Сообщение –

Алгоритм RSA

Шифрование: открытый ключ

Расшифровка: секретный ключ

Сообщение – последовательность чисел в интервале

[0,n – 1].
Для каждого числа вычислить код

Для каждого кода вычислить число исходного сообщения:

Слайд 5

Алгоритм RSA: вычисление Проблема: очень большое число Упрощающая формула: Доказательство:

Алгоритм RSA: вычисление

Проблема:

очень большое число

Упрощающая формула:

Доказательство:

Слайд 6

Алгоритм RSA: вычисление Вычисление y := 1; k:= 1,e конец y := (y*x) mod n;

Алгоритм RSA: вычисление

Вычисление

y := 1;

k:= 1,e

конец

y := (y*x) mod n;

Слайд 7

Быстрое возведение в степень Программирование: Пример: 2 умножения 3 умножения 1 умножение

Быстрое возведение в степень

Программирование:

Пример:

2 умножения

3 умножения

1 умножение

Слайд 8

Быстрое возведение в степень (+ mod) def quickPowMod( x, e,

Быстрое возведение в степень (+ mod)

def quickPowMod( x, e, n ):

b, k, y = x, e, 1
while k:
if k % 2 == 0:
k //= 2
b = (b * b) % n
else:
k -= 1
y = (b * y) % n
return y

def powMod( x, e, n ):
y = 1
for k in range(e):
y = (y*x) % n
return y

0,0000257 сек

28,5 сек

Слайд 9

Алгоритм RSA: пример Шифрование: Сообщение: 1 2 3 зашифрованное сообщение:

Алгоритм RSA: пример

Шифрование:

Сообщение: 1 2 3

зашифрованное сообщение: 1 11 12

Расшифровка:

расшифрованное сообщение:

1 2 3
Слайд 10

Алгоритм RSA: вскрытие Задача: при известном открытом ключе найти секретный

Алгоритм RSA: вскрытие

Задача: при известном открытом ключе найти секретный ключ

Способ:
разложить

n на взаимно-простые множители:
вычислить
найти d, такое что при некотором k

Проблема: разложение большого числа на простые множители требует недостижимого объема вычислений (при длине n > 1024 бита)

Слайд 11

Алгоритм RSA для обмена открытыми ключами можно использовать незащищенный канал

Алгоритм RSA

для обмена открытыми ключами можно использовать незащищенный канал
много готовых реализаций
криптостойкость

(при длине n > 1024 бита)

медленная шифровка и (особенно) расшифровка
при малом n взламывается

Имя файла: Информационная-безопасность.-Современные-алгоритмы-шифрования.pptx
Количество просмотров: 98
Количество скачиваний: 1