Экстернат |
Опубликован: 19.01.2010 | Уровень: специалист | Доступ: свободно
Лекция 11:
Шифрование, использующее современные шифры с симметричным ключом
11.4. Рекомендованная литература
Нижеследующие книги и сайты дают более детальную информацию о предметах, рассмотренных в этой лекции. Пункты, приведенные в квадратных скобках, содержатся в списке в конце книги.
Книги
[Sch99], [Sta06], [PHS03], [Sti06], [MOV97] и [KPS02] рассматривают режимы работы. [Vau06] и [Sta06] дают полные сведения о шифрах потока.
Сайты
Нижеследующие сайты содержат больше информации о темах, обсужденных в этой лекции.
- http: // en.wikipedia.org/wiki/Block_cipher_modes_of_operation
- http://www.itl.nist.gov/fipspubs/fip81.htm
- en.wikipedia.org/wiki/A5/1
- en.wikipedia.org/wiki/RC4
11.5. Итоги
- В реальных приложениях зашифрованный текст имеет переменные размеры и обычно намного большие, чем размер блока, определенный для современных блочных шифров. Режимы работы были изобретены, чтобы зашифровать текст любого размера, который обслуживается современными блочными шифрами. В этой лекции были рассмотрены пять режимов работы.
- Самый простой режим работы называется режимом электронной кодовой книги (ECB — ELECTRONIC CODEBOOK). Исходный текст разделен на N блоков. Размер блока — n бит. Каждый блок использует для шифрования и дешифрования один и тот же ключ.
- В режиме сцепления блоков шифротекста (CBC — Cipher Block Chaining) каждый блок исходного текста прежде чем зашифровывать, складывают по модулю два с предыдущим блоком зашифрованного текста. Когда блок зашифрован, его передают, но его копия сохраняется в памяти, чтобы ее можно было использовать для шифрования следующего блока. Передатчик и приемник согласуют заранее заданный вектор инициализации ( IV ), чтобы складывать его по модулю два с первым блоком зашифрованного текста.
- Чтобы шифровать маленькие модули данных в реальном масштабе времени, применяется режим кодированной обратной связи (CFB — CIPHER FEEDBACK), CFB применяет стандартные блочные шифры, такие как DES или AES, регистр сдвига, но использует операцию сложения по модулю два, чтобы зашифровать или расшифровывать модули данных. Режим CFB использует блочные шифры, но в результате — это шифр потока, потому что каждый модуль данных зашифровывается своим ключом.
- Режим внешней обратной связи (OFB) очень похож на режим CFB, с одной разницей — каждый бит в зашифрованном тексте независим от предыдущего бита или битов. Это позволяет избежать распространения ошибки. Вместо того чтобы использовать предыдущий блок зашифрованного текста, OFB берет предыдущий ключ как информацию обратной связи.
- В режиме счетчика (CTR) нет информации обратной связи. Псевдослучайность в потоке достигается с помощью счетчика. Счетчик на n битов инициализируется установкой заранее заданного значения ( IV ) и увеличивается по заранее заданному правилу.
- Чтобы зашифровать маленькие единицы данных, такие как символы или биты, были разработаны для испытаний несколько шифров потока. Эти шифры потока более эффективны для обработки в реальном масштабе времени. В этой лекции рассматривались только два шифра потока — RC4 и A5/l.
- RC4 — шифр потока, ориентированный на байт, в котором байт ( 8 битов) исходного текста надо сложить по модулю два с байтом ключа, чтобы создать байт зашифрованного текста. Секретный ключ, из которого генерируются однобайтовые ключи в ключевом потоке, может содержать от 1 до 256 байтов. Ключевой генератор потока базируется на перестановке 256 байтов.
- A5/1 — шифр потока, используемый для мобильной телефонной связи. A5/1 создает поток бит из ключа на 64 бита, используя три линейных регистра сдвига.
11.7. Набор для практики
Обзорные вопросы
- Объясните, почему необходимы режимы работы, если для шифровки используются современные блочные шифры.
- Перечислите пять режимов работы, рассмотренных в этой лекции.
- Определите ECB ( ELECTRONIC CODEBOOK) и перечислите его преимущества и недостатки.
- Определите CBC (CIPHER BLOCK CHAINING) и перечислите ее преимущества и недостатки.
- Определите CFB (CIPHER FEEDBACK) и перечислите его преимущества и недостатки
- Определите OFB (OUTPUT FEEDBACK) и перечислите его преимущества и недостатки.
- Определите CTR и перечислите его преимущества и недостатки.
- Разделите пять режимов работы на две группы: те, которые используют функции шифрования и дешифрования, — основные шифры (например, DES или AES), и те, которые используют только функцию шифрования.
- Разделите пять режимов работы на две группы: те, которые требуют дополнение текста, и те, которые не требуют этого.
- Разделите пять режимов работы на две группы: те, которые используют один и тот же ключ для шифрования всех блоков, и те, которые используют ключевой поток для шифровки блоков.
- Объясните основные различия между RC4 и A5/1. Какой из них использует линейный регистр сдвига?
- Каков размер модуля данных в RC4? Каков размер модуля данных в A5/1?
- Перечислите режимы работы, которые могут быть ускорены параллельной обработкой.
- Перечислите режимы работы, которые могут использоваться для шифровки файлов произвольного доступа.
Упражнения
- Покажите, почему режим CFB создает несинхронный шифр потока, а режим OFB создает синхронный.
- Сколько блоков затрагивает единственный бит ошибки в передаче в режиме CFB?
- В режиме ECB бит 17 в зашифрованном тексте блока 8 разрушен в течение передачи. Найдите возможные разрушенные биты в исходном тексте.
- В режиме CBC биты 17 и 18 в зашифрованном тексте блока 9 в процессе передачи были разрушены. Найдите возможные разрушенные биты в исходном тексте.
- В режиме CFB биты 3-6 в зашифрованном тексте блока 11 разрушены ( r = 8 ). Найдите возможные разрушенные биты в исходном тексте.
- В режиме CTR блоки 3 и 4 полностью разрушены. Найдите возможные разрушенные биты в исходном тексте.
- В режиме OFB полный зашифрованный текст блока 11 разрушен ( r = 8 ). Найдите возможные разрушенные биты в исходном тексте.
- Докажите, что исходный текст, используемый Алисой, может быть восстановлен Бобом в режиме CFB.
- Докажите, что исходный текст, используемый Алисой, может быть восстановлен Бобом в режиме OFB.
- Докажите, что исходный текст, используемый Алисой, может быть восстановлен Бобом в режиме CTR.
- Покажите диаграмму для шифрования и дешифрования в режиме CFB, когда r = n.
- Покажите диаграмму для шифрования и дешифрования в режиме OFB, когда r = n.
- Покажите процесс, используемый для алгоритма дешифрования в режиме ECB, если применяется захват зашифрованного текста (CTS).
- Покажите диаграммы шифрования и дешифрования для режима ECB (только последние два блока), когда используется захват зашифрованного текста (CTS).
- Покажите процесс, используемый для алгоритма дешифрования в режиме CBC, если применяется захват зашифрованного текста (CTS).
- Покажите шифрование и диаграмму дешифрования для режима CBC (только последние два блока), когда используется захват зашифрованного текста (CTS).
- Объясните, почему нет потребности в захвате зашифрованного текста в режимах CFB, OFB и CTR (CIPHER FEEDBACK, OUTPUT FEEDBACK).
- Покажите эффект распространения ошибки, когда ECB (ELECTRONIC CODEBOOK) использует методику CTS.
- Покажите эффект распространения ошибки, когда CBC использует методику CTS.
- Режим Формирование цепочки блоков является вариантом, в котором все предыдущие блоки зашифрованного текста перед шифрованием складываются по модулю два с текущим исходным текстом. Выведите рисунок-диаграмму, которая показывает шифрование и дешифрование.
- Режим размножения Цепочка блоков шифротекста (PCBC) является вариантом CBC, в котором перед шифрованием предыдущий блок исходного текста и предыдущий блок зашифрованного текста складывается по модулю два с текущим блоком исходного текста. Нарисуйте диаграмму, которая показывает шифрование и дешифрование.
- Режим Цепочка блоков шифротекста с контрольной суммой (CBCC) является вариантом CBC, в котором все предыдущие блоки исходного текста перед шифрованием складываются по модулю два с текущим блоком исходного текста. Нарисуйте диаграмму, чтобы показать шифрование и дешифрование и проиллюстрировать процедуру.
- В RC4 покажите первые 20 элементов ключевого потока, если ключ засекречивания — 7 байтов со значениями 1, 2, 3, 4, 5, 6 и 7. Вы можете при желании написать маленькую программу.
- В RC4 найдите значение для ключа засекречивания, который не изменяет матрицу состояний после первого и второго шагов инициализации.
- Алиса обменивается сообщениями с Бобом, используя в RC4 для засекречивания 16 -байтовый ключ засекречивания. Ключ засекречивания изменяется каждый раз, используя рекурсивное определение K = (Ki-1+Ki-1 )mod 2128. Покажите, сколькими сообщениями они могут обменяться перед тем, как текст начнет повторяться.
- В A5/1 найдите максимальный период каждого линейного регистра сдвига.
- В A5/1 найдите значение следующих функций. В каждом случае показать, сколько синхронизируется линейных регистров сдвига.
- Majority (1, 0, 0)
- Majority (0, 1, 1)
- Majority (0, 0, 0)
- Majority (1, 1, 1)
- В A5/1 найдите выражение для мажоритарной функции.
- Напишите алгоритм дешифрования в псевдокоде для режима ECB.
- Напишите алгоритм дешифрования в псевдокоде для режима CBC.
- Напишите псевдокод алгоритма дешифрования для режима CFB.
- Напишите алгоритм дешифрования в псевдокоде для режима OFB.
- Напишите алгоритм дешифрования в псевдокоде для режима CTR.
- Напишите алгоритм для shiftleft -процедуры, используемой в алгоритме 11.4.
- Напишите алгоритм для selectleft -процедуры, используемой в алгоритме 11.4.
- Напишите алгоритм для процедуры конкатенации, используемой в алгоритме 11.4.