Файл: Разработка программного обеспечения алгоритма Диффи Хелмана на основе эллиптических кривых.docx

ВУЗ: Не указан

Категория: Не указан

Дисциплина: Не указана

Добавлен: 22.11.2023

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

Скачиваний: 2

ВНИМАНИЕ! Если данный файл нарушает Ваши авторские права, то обязательно сообщите нам.

СОДЕРЖАНИЕ

Программная реализация

Результаты

Часть 1: эллиптические кривые над вещественными числами и групповой закон

Эллиптические кривые

Группы

Групповой закон для эллиптических кривых

Геометрическое сложение

Алгебраическое сложение

Скалярное умножение

Логарифм

Часть 2: эллиптические кривые над конечными полями и задача дискретного логарифмирования

Поле целых чисел по модулю p

Эллиптические кривые над 

Сложение точек

Алгебраическая сумма

Порядок группы эллиптической кривой

Скалярное умножение и циклические подгруппы

Дискретный логарифм

Часть 3: ECDH и ECDSA

Параметры области определения

Криптография на эллиптических кривых

Часть 4: алгоритмы для взлома защиты ECC и сравнение с RSA

Взлом задачи дискретного логарифмирования

Baby-step, giant-step

ρ Полларда

Сравниние ρ Полларда и Baby-step giant-step

Дальнейшие рассуждения

.

В частности, я рассмотрю следующие темы:


  1. Эллиптические кривые над вещественными числами и групповой закон

  2. Эллиптические кривые над конечными полями и задача дискретного логарифмирования

  3. Генерирование пар ключей и два алгоритма ECC: ECDH и ECDSA

  4. Алгоритмы для взлома защиты ECC и сравнение с RSA


Для понимания статьи вам нужно знать основы теории множеств, геометрии и модулярной арифметики, понимать принципы симметричной и асимметричной криптографии. Наконец, вы должны чётко понимать, что такое «простая» и «сложная» задачи и их роли в криптографии.

Готовы? Приступим!


Часть 1: эллиптические кривые над вещественными числами и групповой закон



Эллиптические кривые



Во-первых: что такое эллиптическая кривая? В Wolfram MathWorld есть отличное и исчерпывающее определение. Но для нас достаточно того, что эллиптическая кривая — это просто множество точек, описываемое уравнением:



где  , (это необходимо, чтобы исключить особые кривые). Приведённое выше уравнение называется обычной формулировкой Вейерштрасса для эллиптических кривых.




Различные формы эллиптических кривых (  изменяется от 2 до -3).




Виды особенностей: слева — кривая с точкой возврата (каспом) ( ). Справа — кривая с самопересечением ( ). Оба этих примера не являются полноценными эллиптическими кривыми.

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

Для наших целей нам также понадобится, чтобы частью кривой являлась бесконечно удалённая точка (также известная как идеальная точка). С этого момента мы будем обозначать бесконечно удалённую точку символом 0 (ноль).



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

Группы



В математике группа — это множество, для которого мы определили двоичную операцию, называемую «сложением» и обозначаемую символом +. Чтобы множество   было группой, сложение нужно определить таким образом, чтобы оно соответствовало четырём следующим свойствам:


  1. замыкание: если   и   входят в  , то   входит в  ;

  2. ассоциативность:  ;

  3. существует единичный элемент 0, такой, что  ;

  4. у каждого элемента есть обратная величина, то есть: для каждого   существует такое  , что  .


Если мы добавим пятое требование:


  1. коммутативность:  ,


то группа называется абелевой группой.

При обычной записи сложения множество целых чисел   является группой (более того, это абелева группа). Множество натуральных чисел  , однако, не является группой, потому что не удовлетворяет четвёртому свойству.

Группы удобны тем, что если мы докажем соблюдение всех четырёх свойств, то получим автоматически некоторые другие свойства «в нагрузку». Например: 
единичный элемент уникален; кроме того, обратные величины уникальны, то есть: для каждого   существует единственное  , такое, что   (и мы можем записать   как  ). Непосредственно или косвенно эти и другие свойства групп очень пригодятся нам в будущем.


Групповой закон для эллиптических кривых



Мы можем определить группу для эллиптических кривых. А именно:


  • элементы группы являются точками эллиптической кривой;

  • единичный элемент — это бесконечно удалённая точка 0;

  • обратная величина точки   — это точка, симметричная относительно оси  ;

  • сложение задаётся следующим правилом: сумма трёх ненулевых точек   и  , лежащих на одной прямой, будет равна  .





Сумма трёх точек, находящихся на одной прямой, равна 0.

Стоит учесть, что в последнем правиле нам требуются только три точки на одной прямой, и порядок расположения этих трёх точек не важен. Это значит, что если три точки   и   лежат на одной прямой, то  . Таким образом мы интуитивно доказали, что наш оператор + обладает свойствами ассоциативности и коммутативности: мы находимся в абелевой группе.

Пока всё идёт отлично. Но как нам вычислить сумму двух произвольных точек?

Геометрическое сложение



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