Читаем 1c2b9509b53cb0837976a7dc6c8bcd37 полностью

единицу. Перемножим эти три числа между собой и получим результат — 105.

А теперь представим, что у нас имеется только конечный результат 105 и нам

необходимо разложить его обратно на простые множители, то есть получить

исходные числа 3, 5 и 7. При решении задачи даже для такого небольшого

трехразрядного числа человек столкнется с трудностями. А задача о

факторизации чисел, имеющих разрядность в десятки позиций, и для

современного компьютера может стать весьма нетривиальной. Безусловно, существуют алгоритмы, которые позволяют осуществлять факторизацию

несколько эффективнее, чем простым перебором делителей, но однозначно

оптимального алгоритма, позволяющего быстро решить эту задачу для

больших чисел, пока не изобрели.

Проблема факторизации чисел занимала умы ученых еще сотни лет назад.

Одним из первых, кто занялся этой задачей, стал французский математик Пьер

де Ферма. Еще в 1643 году он предложил свой метод факторизации, который

используется для криптоанализа шифров RSA и в наши дни. Понятно, что для

любого алгоритма шифрования всегда найдутся люди, которые будут искать

возможности для эффективной атаки на него. Кто-то в преступных целях, а кто-

то в научных — чтобы исследовать криптостойкость алгоритма и защитить

проекты, базирующиеся на данном решении. Еще в середине 2000-х гг. стали

появляться сообщения о том, что группа ученых того или иного университета

взломала сначала 512-битный, а затем и 1024-битный ключ RSA. При этом они

не задействовали какую-то исключительную вычислительную мощность, а для

решения задачи им потребовалось вполне разумное время. Конечно, ни один, даже самый мощный компьютер, с такой вычислительной нагрузкой в одиночку

не справится, поэтому для решения подобных задач компьютеры обычно

объединяют в специальные вычислительные кластеры.

За последние десять лет вычислительная мощность компьютеров заметно

выросла. Согласно закону Мура, производительность компьютерных

процессоров удваивается каждые 18 месяцев, поэтому для поддержания

криптостойкости алгоритма RSA в различных технологических решениях

необходимо постоянно увеличивать длину открытого ключа. Поскольку до

бесконечности этот процесс продолжаться не может, от данного алгоритма

стали отказываться и переходить к более прогрессивным решениям, в которых

достаточная криптостойкость поддерживается для ключей с разумной

разрядностью — в пределах 256–1024 бит. Одним из таких стал алгоритм

формирования цифровой подписи DSA, построенный на модели дискретного

логарифмирования. В данном алгоритме используется так называемая

модульная арифметика, которая представляет собой задачу поиска степени, в

которую необходимо возвести заданное число, чтобы, разделив результат по

модулю на другое заданное число, получить желаемый остаток от деления.

Чтобы стало понятнее, рассмотрим следующий пример: Деление по модулю — это обычное деление целых чисел друг на друга с

целым остатком. Подобную арифметическую операцию проходят в младших

классах школы, непосредственно перед изучением дробей. После чего про

деление с остатком благополучно забывают и не вспоминают до

университетского курса высшей математики. Где неожиданно выясняется, что

деление с остатком на самом деле играет довольно важную роль в теории

чисел и алгебре. В нашем примере мы должны определить, в какую степень

нам надо возвести тройку, чтобы потом, разделив полученный результат по

модулю на 17, получить число 13 в качестве остатка от деления. Правильный

ответ: x = 4. То есть 34 = 81, 81/17 = 4 + остаток 13 (проверка: 4 x 17 = 68 + 13 =

81). Довольно просто, не правда ли? Возводя тройку в различные степени x от

единицы и более, а затем деля по модулю полученный результат на 17, мы

будем каждый раз получать различные остатки от деления. Однако у них будет

одно общее свойство — все эти остатки будут находиться в диапазоне от 1 до

16 включительно, но выстраиваться отнюдь не по порядку (по мере

последовательного возрастания степени x). Множество этих чисел называется

кольцом вычетов. Кольцом, потому что остатки будут постоянно повторяться

для разных показателей степени, в которую возводится базовое число. А

теперь представим, что мы оперируем не одно-двухразрядными, а очень

большими числами. В этих случаях, если степень заданного числа нам заранее

неизвестна, то задача ее нахождения для конкретных величин остатков

становится очень и очень сложной. Именно эта сложность и лежит в основе

алгоритма DSA.

Как уже упоминалось выше, все подобные алгоритмы шифрования построены

на принципе, при котором задача в одну сторону решается очень быстро и

просто, а в обратную — исключительно сложно. И алгоритм DSA — не

исключение. Если мы будем решать задачу для больших чисел путем простого

перебора различных значений, то данный метод будет работать очень

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

современных компьютеров, математики вынуждены были задуматься о

Перейти на страницу:

Похожие книги

Linux
Linux

Книга посвящена операционной системе Linux. Приводятся подробные сведения о ее особенностях и возможностях, идеологии файловой системы, инсталляции и основных командах, вопросах компиляции ядра, настройках и сервисах. Большое внимание уделяется организации на базе Linux различных серверов и служб: электронной почты, WWW, FTP, INN, Proxy, NTP, а также проблемам администрирования сети, обеспечения безопасной работы и другим вопросам. Описаны способы настройки под Linux рабочих станций, в т. ч. и бездисковых, установки и эксплуатации на них графических сред типа X Window, а также конфигурирование модемных соединений, принтеров и сканеров, отладка взаимодействия с Linux-машинами такой «экзотической» периферии, как карманные компьютеры, мобильные телефоны, TV-тюнеры и т. п. Рассматриваемые в книге конфигурационные файлы и структура каталогов соответствуют дистрибутиву Red Hat Linux 7.x, тем не менее, при минимальной адаптации все упоминаемые в книге пакеты устанавливаются в любом дистрибутиве Linux.Для начинающих администраторов или пользователей Linux.

Алексей Александрович Стахнов

ОС и Сети, интернет
Атака на Internet
Атака на Internet

Эта книга является одним из первых специализированных изданий, написанных отечественными авторами, которое посвящено обстоятельному анализу безопасности сети Internet. В книге предлагаются и подробно описываются механизмы реализации основных видов удаленных атак как на протоколы TCP/IP и инфраструктуру Сети, так и на многие популярные сетевые операционные системы и приложения.Особое внимание авторы уделили причинам возникновения и успеха удаленных атак, а также их классификации. Были также рассмотрены основные способы и методы защиты от удаленных атак.Издание предназначено для сетевых администраторов и пользователей Internet, администраторов безопасности, разработчиков систем защит, системных сетевых программистов, студентов и аспирантов вузов, а также для всех интересующихся вопросами нарушения и обеспечения информационной безопасности компьютерных сетей.

Дмитрий Геннадьевич Леонов , Илья Давыдович Медведовский , Павел Валентинович Семьянов

ОС и Сети, интернет / Интернет / Книги по IT
Как раскрутить и разрекламировать Web-сайт в сети Интернет
Как раскрутить и разрекламировать Web-сайт в сети Интернет

Настоящая книга заинтересует всех, кто столкнулся с вопросами подготовки, размещения в Сети и популяризации Internet ресурсов различного уровня: от домашней странички до корпоративного сайта. В ней вы найдете все, что необходимо для оптимизации Web сайтов под поисковые системы: приемы написания Web-страниц, описание множества самых популярных специализированных программ, предназначенных для подготовки сайта и его раскрутки, создания удачного HTML-кода страниц с правильными метаданными.Книга является практическим руководством для разработчиков Web сайтов и всех, занимающихся их продвижением. Автор приводит множество советов, касающихся создания и анонсирования Web страниц. Рассмотрены средства автоматизации для повышения эффективности разработки и маркетинга при создании и обслуживании сайта. Описание программных и сетевых средств, автоматизирующих процессы тестирования и отладки сайта, обеспечивающих проверку работоспособности и корректности гиперссылок, синтаксиса HTML кода и грамматики размещенного на странице текста, занимает центральное место в книге. Подробно излагаются возможности таких программ, как Linkbot Developer Edition, Domain NameChecker, Retrieve, CyberSpyder Link Test, HTML Link Validator, CSE HTML Validator, A Real Validator, MetaTag ToolKit, MetaMan, WebQA.Отдельная глава посвящена регистрации Web ресурсов в поисковых системах и каталогах. Описываются программы автоматической регистрации (WebPosition, Page Promoter, Web Регистратор), способы взаимодействия с индексирующими роботами поисковых машин, правила применения метаданных. Рассматриваются приемы и методы рекламы сайтов в Internet, указаны критерии ее эффективности.Издание рассчитано на широкий круг читателей и будет полезно как начинающим создателям Web сайтов, так и профессионалам, которые хотят научиться более качественно продвигать в Сети свой Web продукт.

Александр Петрович Загуменнов

ОС и Сети, интернет