Криптография с симметричным ключом (или симметричное шифрование) - это один из видов шифрования данных в которых один и тот же ключ используется как для шифрования, так и для дешифрования. Такой метод кодирования информации широко распространен в последние десятилетия для облегчения тайного общения между правительством и военными. В настоящее время алгоритмы симметричного ключа широко применяются в различных типах компьютерных систем для повышения безопасности данных.
Как это работает?
Симметричная схема шифрования основана на одном ключе, который используется двумя или более пользователями. Этот же ключ используется для шифрования и дешифрования так называемого открытого текста (который содержит сообщение или часть закодированных данных). Процесс шифрования состоит из обработки открытого текста (ввода) алгоритмом шифрования, называемый шифром, который в свою очередь генерирует зашифрованный текст (вывод).
Если схема шифрования достаточно надежна, единственный способ для человека прочитать или получить доступ к информации, содержащейся в зашифрованном тексте, это использовать соответствующий ключ для его расшифровки. Процесс расшифровки в основном преобразовывает зашифрованный текст обратно в открытый.
Безопасность симметричных систем шифрования основана на том, насколько трудно случайным образом угадать соответствующий ключ. Например, для расшифровки 128-битного ключа с помощью обычного компьютерного оборудования, потребуются миллиарды лет. Чем длиннее ключ, тем сложнее его взломать. Ключи длиной 256 бит обычно считаются высоко-защищенными и теоретически устойчивыми к атакам методом "грубой силы" с помощью квантового компьютера.
Две наиболее распространенных симметричных схем шифрования, используемые сегодня, основаны на блочном и потоковом шифре. Блочные шифры группируют данные в блоки заранее определенного размера, и каждый блок шифруется с использованием соответствующего ключа и алгоритма шифрования (например, 128-битный текст шифруется в 128-битный зашифрованный текст). В потоковом шифре данные открытого текста шифруются не блоками, а инкрементом в 1 бит (1-битный текст зашифровывается в 1-битный зашифрованный текст).
Симметричное и асимметричное шифрование
Использование двух ключей вместо одного, также приводит к различным функциональным различиям между симметричным и асимметричным шифрованием. Асимметричные алгоритмы являются более сложными и медленными, чем симметричные. Поскольку публичный и приватный ключи, используемые в асимметричном шифровании в некоторой степени математически взаимосвязаны. Сами ключи также должны быть значительно длиннее, чтобы обеспечить аналогичный уровень безопасности предлагаемый более короткими симметричными ключами.
Применение в современных компьютерных системах
Симметричные алгоритмы шифрования используются во многих современных компьютерных системах для повышения безопасности данных и конфиденциальности пользователей. Расширенный стандарт шифрования (AES), который широко используется как в приложениях для безопасного обмена сообщениями, так и в облачных хранилищах, является одними из ярких примеров симметричного шифра.
В дополнение к программной реализации, AES также может быть использован непосредственно в компьютерном оборудовании. Схемы аппаратного симметричного шифрования обычно используют AES 256, который является определенным вариантом расширенного стандарта шифрования с размером ключа в 256 бит.
Общая путаница заключается в том, что ECDSA основан на криптографии с эллиптической кривой (ECC), которая в свою очередь, может применяться для множества задач, включая шифрование, цифровые подписи и псевдослучайные генераторы. Однако сам ECDSA не может использоваться для шифрования.
Преимущества и недостатки
Симметричные алгоритмы обеспечивают довольно высокий уровень безопасности и в то же время позволяют быстро шифровать и дешифровать сообщения. Относительная простота симметричных систем также является логистическим преимуществом, поскольку они требуют меньшей вычислительной мощности, чем асимметричные. Кроме того, безопасность, обеспечиваемая симметричным шифрованием, может быть улучшена простым увеличением длины ключа. Для каждого отдельного бита, добавляемого к длине симметричного ключа, сложность взлома шифрования посредством атаки методом перебора, экспоненциально увеличивается.