Группе инженеров из Японии, Швейцарии, Нидерландов и США удалось
успешно вычислить данные, зашифрованные при помощи криптографического
ключа стандарта RSA длиной 768 бит. По словам исследователей, после их
работы в качестве надежной системы шифрования можно рассматривать
только RSA-ключи длиной 1024 бита и более. Все, что имеет длину ключа
менее 768 бит уже можно взломать, правда к этому придется приложить
определенные усилия.
Взломать систему шифрования группе удалось в начале декабря, однако
научный доклад на эту тему они представили лишь сегодня. Сами авторы
метода говорят, что их работы могут быть определены как незаконные в
некоторых странах, так как алгоритм RSA много где используется для
государственных и военных нужд, однако исследователи говорят, что их
работа - это чисто академический интерес и ни одного реального ключа,
находящегося в использовании они не взломали. Хотя сделать это было бы
возможно.
Как следует из описания работы, вычисление значений ключа инженеры
проводили методом факторизации модульных чисел. Основан метод на
сравнительно простых арифметических действиях, правда объединенных в
довольно сложные формулы.
По словам Андрея Тимофеева из института CWI в Амстердаме, для своих
расчетов они применяли самое обычное оборудование, доступное в продаже.
Первым шагом во взломе системы стало вычисление подходящих простых
множителей. Если бы это процесс проводился базовым методом перебора, то
на процессоре AMD Opteron 2.2 ГГц он бы занял около 1500 лет и около 5
терабайт данных. Однако исследователи приняли решение использовать
многомерные математические матрицы.
Составление кластера матриц заняло всего около 12 часов. На базе матриц
размерностью 2200 на 2200 ученые определили множители, дальнейшие
процессы вычисления шли значительно быстрее и уже на базе современных
многоядерных процессоров. В итоге группе удалось вычислить 232-цифровой
ключ, открывающий доступ к зашифрованным данным.
Исследователи уверены, что используя их метод факторизации, взломать 512-битный RSA-ключ можно было еще лет 5-10 назад.
|