Односторонняя функция
Нерешённые проблемы информатики: ''Существуют ли односторонние функции ?''
Односторонняя функция — математическая функция, которая легко вычисляется для любого входного значения, но трудно найти аргумент по заданному значению функции. Здесь «легко» и «трудно» должны пониматься с точки зрения теории сложности вычислений. Разрыв между сложностью прямого и обратного преобразований определяет криптографическую эффективность односторонней функции. Неинъективность функции не является достаточным условием для того, чтобы называть её односторонней. Односторонние функции могут называться также трудно обратимыми или необратимыми.
Существование односторонних функций до сих пор не доказано. Их существование докажет, что классы сложности P и NP не равны, попутно разрешив ряд вопросов теоретической информатики. Современная асимметричная криптография основывается на предположении, что односторонние функции всё-таки существуют.
Односторонние функции являются фундаментальными инструментами криптографии, персональной идентификации, аутентификации и других областей защиты данных. Хотя существование таких функций по-прежнему остаётся недоказанной гипотезой, существует несколько претендентов, выдержавших десятилетия пристального изучения. Многие из них являются неотъемлемой частью большинства телекоммуникационных систем, а также систем электронной коммерции и интернет-банкинга по всему миру.
Содержание
1 Определение
2 Существование
3 Использование
3.1 Доказательство выполнения работы
3.2 Стойкость криптографических схем
4 Кандидаты в односторонние функции
4.1 Умножение и факторизация
4.2 Возведение в квадрат и извлечение квадратного корня по модулю
4.3 Дискретное экспоненцирование и логарифмирование
4.4 Криптографические хеш-функции
4.5 Другие претенденты
5 См. также
6 Примечания
7 Ссылки
Определение |
Пусть {0,1}n{displaystyle {0,1}^{n}} — множество всех двоичных строк длины n. Функция f:{0,1}∗→{0,1}∗{displaystyle f:{0,1}^{*}rightarrow {0,1}^{*}} является односторонней функцией, если она эффективно вычисляется за полиномиальное время на детерминированной машине Тьюринга, но не существует полиномиальной вероятностной машины Тьюринга, которая обращает эту функцию с более чем экспоненциально малой вероятностью. То есть для любой вероятностной полиномиальной машины M{displaystyle M}, для любого полинома p(n){displaystyle p(n)} и достаточно большого n∈N{displaystyle nin mathbb {N} } выполняется:
- Pr[M(f(m))∈f−1(m)]<1/p(n){displaystyle Pr[M(f(m))in f^{-1}(m)]<1/p(n)}
где строка m{displaystyle m} выбирается случайным образом на множестве {0,1}n{displaystyle {0,1}^{n}} в соответствии с равномерным законом распределения. Время работы машины M{displaystyle M} ограничено полиномом от длины искомого прообраза[1].
Существование |
Существование односторонних функций не доказано. Если f является односторонней функцией, то нахождение обратной функции является трудновычислимой (по определению), но легкопроверяемой задачей (путём вычисления f на ней). Таким образом, из существования односторонней функции следует, что P ≠ NP. Однако, неизвестно, влечёт ли за собой P ≠ NP существование односторонних функций.
Существование односторонних функций повлечёт за собой существование многих других полезных криптографических объектов, в том числе:
генераторов псевдослучайных чисел;- если существует односторонняя функция с трудным битом, то существует битовая схема обязательств;
семейства псевдослучайных функций ;
имитовставки;
электронной цифровой подписи.
Использование |
Говорят, что односторонняя функция сохраняет длину, если битовая длина значения функции равна битовой длине аргумента. Такие функции используются, например, в псевдослучайных генераторах. Если битовая длина значения односторонней функции постоянна при любой длине аргумента, то она называется хеш-функцией. Так, хеш-функция используется для хранения паролей или создания электронной подписи[1].
Трудность задачи построения криптографических схем из односторонних функций можно пояснить на следующем примере. Пусть f{displaystyle f} — односторонняя функция и нам требуется построить криптосистему с секретным ключом. В такой криптосистеме имеется только один ключ — секретный, который известен и отправителю, и получателю шифрованного сообщения. Алгоритмы шифрования EK{displaystyle E_{K}} и дешифрования DK{displaystyle D_{K}} оба зависят от этого секретного ключа K{displaystyle K} и таковы, что DK(EK(m))=m{displaystyle D_{K}(E_{K}(m))=m} для любого открытого текста m{displaystyle m}. Ясно, что если криптограмму d{displaystyle d} сообщения m{displaystyle m} вычислять как d=f(m){displaystyle d=f(m)}, то противник, перехвативший d{displaystyle d}, может вычислить m{displaystyle m} лишь с пренебрежимо малой вероятностью. Но во-первых, непонятно, каким образом сможет восстановить сообщение m{displaystyle m} из криптограммы законный получатель? Во-вторых, из того, что функция f{displaystyle f} односторонняя следует лишь, что противник не может вычислить все сообщение целиком. А это — весьма низкий уровень стойкости. Желательно, чтобы противник, знающий криптограмму d{displaystyle d}, не мог вычислить ни одного бита открытого текста.
Для решения первой задачи были придуманы односторонние функции с потайным входом. Это специальный тип односторонней функции для которой легко вычислить f(m){displaystyle f(m)} по заданному m{displaystyle m}, но трудно по известному f(m){displaystyle f(m)} вычислить m{displaystyle m}. Однако существует некоторая дополнительная секретная информация y{displaystyle y}, позволяющая при знании f(m){displaystyle f(m)} и y{displaystyle y} легко вычислить m{displaystyle m}.
Еще одним примером использования односторонних функций в криптографических схемах является следующая схема аутентификации:
Абонент A{displaystyle A} вырабатывает следующую последовательность сообщений: m0,m1=f(m0),m2=f(m1){displaystyle m_{0},m_{1}=f(m_{0}),m_{2}=f(m_{1})} и т. д. m100=f(m99){displaystyle m_{100}=f(m_{99})}, где f(m){displaystyle f(m)} — односторонняя функция. Затем m100{displaystyle m_{100}} передается по секретному каналу (или при встрече) абоненту B{displaystyle B}. Когда A{displaystyle A} необходимо подтвердить свою личность, он передаёт B{displaystyle B} по открытому каналу сообщение m99{displaystyle m_{99}}. B{displaystyle B} проверяет: f(m99)=?m100{displaystyle f(m_{99})=?m_{100}}. В следующий раз A{displaystyle A} передаст m98{displaystyle m_{98}}, и B{displaystyle B} проверит: f(m98)=?m99{displaystyle f(m_{98})=?m_{99}} и т. д. Перехват сообщений на i-ом этапе в открытом канале ничего не даст злоумышленнику, так как он не сможет получить соответствующее значение mi−1{displaystyle m_{i-1}}, чтобы в следующий раз идентифицировать себя как абонента A{displaystyle A}. Такие схемы применяются для идентификации «свой/чужой»[2].
Доказательство выполнения работы |
Для защиты компьютерных систем от злоупотребления услугами запрашивающей стороне предлагается решить задачу, на поиск решения которой тратится достаточно много времени, а результат легко и быстро проверяется обслуживающей стороной. Примером такой защиты от спама может служить система Hashcash[3], которая запрашивает хеш частичной инверсии у отправляющей электронную почту стороне.
В системе «Биткойн» требуется, чтобы получаемая хеш-сумма была меньше специального параметра. Для поиска нужной хеш-суммы требуется её многократный пересчёт с перебором произвольных значений дополнительного параметра. На поиск одной хеш-суммы все компьютеры системы тратят примерно 10 минут, что регулирует скорость эмиссии новых биткойнов. Для проверки требуется лишь однократное вычисление хеша.
Стойкость криптографических схем |
Существование односторонних функций является необходимым условием для стойкости многих типов криптографических схем. В некоторых случаях этот факт устанавливается достаточно просто. Рассмотрим функцию f{displaystyle f} такую, что f(r)=K1{displaystyle f(r)=K_{1}}. Она вычислима с помощью алгоритма G{displaystyle G} за полиномиальное время. Покажем, что если f{displaystyle f} не односторонняя функция, то криптосистема нестойкая. Предположим, что существует полиномиальный вероятностный алгоритм A{displaystyle A}, который инвертирует f{displaystyle f} с вероятностью по крайней мере 1/p(n){displaystyle 1/p(n)} для некоторого полинома p{displaystyle p}. Здесь n{displaystyle n} — длина ключа K1{displaystyle K_{1}}. Атакующий может подать на вход алгоритму A{displaystyle A} ключ K1{displaystyle K_{1}} и получить с указанной вероятностью некоторое значение r′{displaystyle r'} из прообраза. Далее злоумышленник подает r′{displaystyle r'} на вход алгоритма G{displaystyle G} и получает пару ключей (K1,K2′){displaystyle (K_{1},K'_{2})}. Хотя K2′{displaystyle K'_{2}} не обязательно совпадает с K2{displaystyle K_{2}}, тем не менее, по определению криптосистемы DK2′(EK1(m))=m{displaystyle D_{K_{2}'}(E_{K_{1}}(m))=m} для любого открытого текста m{displaystyle m}. Поскольку K2′{displaystyle K'_{2}} найден с вероятностью по крайней мере 1/p(n){displaystyle 1/p(n)}, которая в криптографии не считается пренебрежимо малой, криптосистема нестойкая.
Из всего сказанного следует, что предположение о существовании односторонних функций является самым слабым криптографическим предположением, которое может оказаться достаточным для доказательства существования стойких криптографических схем различных типов. На выяснение того, является ли это условие и в самом деле достаточным, направлены значительные усилия специалистов.
На настоящий момент доказано, что существование односторонних функций является необходимым и достаточным условием для существования стойких криптосистем с секретным ключом, а также стойких криптографических протоколов нескольких типов, включая протоколы электронной подписи. С другой стороны, имеется результат Импальяццо и Рудиха, который является достаточно сильным аргументом в пользу того, что для некоторых типов криптографических схем (включая протоколы распределения ключей типа Диффи-Хеллмана) требуются более сильные предположения, чем предположение о существовании односторонних функций[4].
Кандидаты в односторонние функции |
Далее описаны несколько претендентов на односторонние функции. На данный момент не известно, являются ли они действительно односторонними, но обширные исследования пока не смогли найти эффективный обратный алгоритм к каждой из них.
Умножение и факторизация |
Функция f{displaystyle f} принимает на вход два простых числа p{displaystyle p} и q{displaystyle q} в двоичном представлении и возвращает их произведение N=f(p,q){displaystyle N=f(p,q)}. Эта функция может быть вычислена за время порядка O{displaystyle O}(n2){displaystyle (n^{2})}, где n{displaystyle n} — общая длина (количество двоичных чисел) входных данных. Построение обратной функции требует нахождения множителей заданного целого числа N{displaystyle N}. Определение множителей является очень трудоёмкой вычислительной операцией. Для оценки сложности алгоритма, раскладывающего целое число N{displaystyle N} на простые множители, часто используют функцию:
- LN(α,β)=exp((β+o(1)(lnN)α(lnlnN)1−α)){displaystyle L_{N}(alpha ,beta )=exp((beta +o(1)(ln N)^{alpha }(ln ln N)^{1-alpha }))}
Если алгоритм имеет сложность O(LN(0,β)){displaystyle O(L_{N}(0,beta ))}, то ему требуется полиномиальное время на работу (размер задачи на входе, число бит числа, lnN{displaystyle ln N}). При сложности O(LN(1,β)){displaystyle O(L_{N}(1,beta ))} ему потребуется уже экспоненциальное время. Таким образом скорость роста функции LN(α,β){displaystyle L_{N}(alpha ,beta )} при 0<α<1{displaystyle 0<alpha <1} лежит между полиномиальной и экспоненциальной. Поэтому про алгоритмы с такой сложностью говорят, что они требуют суб-экспоненциального времени[5].
Существует несколько методов факторизации числа N=p∗q{displaystyle N=p*q} с простыми p{displaystyle p} и q{displaystyle q}. Некоторые из них:
Пробное деление — в этом алгоритме для всех простых чисел p{displaystyle p}, не превосходящих N{displaystyle {sqrt {N}}}, проверяется условие N/p∈Z{displaystyle N/pin mathbb {Z} }. Такой алгоритм близок к полному перебору и имеет экспоненциальную сложность O(LN(1,1)){displaystyle O(L_{N}(1,1))}.
Метод эллиптической кривой хорошо работает, если один из простых множителей p{displaystyle p} не превосходит 250{displaystyle 2^{50}}. Его сложность оценивается как Lp(1/2,c){displaystyle L_{p}(1/2,c)}.
Квадратичное решето, вероятно, наиболее быстрый способ разложения чисел, лежащих между 1080{displaystyle 10^{80}} и 10100{displaystyle 10^{100}}. Его сложность — Lp(1/2,1){displaystyle L_{p}(1/2,1)}.
Квадратичное решето в числовом поле. В настоящее время это наиболее успешный метод для чисел, насчитывающих 100 и более десятичных знаков. С его помощью можно разлагать на множители числа до 10155{displaystyle 10^{155}}, а его сложность оценивается как LN(1/3,(64/9)13){displaystyle L_{N}(1/3,;(64/9)^{frac {1}{3}})}[5].
Функция может быть обобщена на диапазон полупростых чисел. Заметим, что f{displaystyle f} не сможет быть односторонней для произвольных p,q>1{displaystyle p,q>1}, так как их произведение с вероятностью ¾ имеет множитель 2.
Заметим, что факторизация с полиномиальной сложностью возможна на квантовом компьютере с помощью алгоритма Шора (класс BQP).
Возведение в квадрат и извлечение квадратного корня по модулю |
Функция f{displaystyle f} принимает два целых числа: x{displaystyle x} и N{displaystyle N}, где N{displaystyle N} — произведение двух простых p{displaystyle p} и q{displaystyle q}. На выходе — остаток от деления x2{displaystyle x^{2}} на N{displaystyle N}. Нахождение обратной функции требует вычисления квадратного корня по модулю N{displaystyle N}, то есть нахождения x{displaystyle x} если известно y{displaystyle y} и то, что x2modN=y{displaystyle x^{2}{bmod {N}}=y}. Можно показать, что последняя задача вычислительно так же сложна, как и разложение N{displaystyle N} на множители.
Криптосистема Рабина основывается на предположении, что функция Рабина является односторонней.
Дискретное экспоненцирование и логарифмирование |
Функция дискретного экспоненцирования f{displaystyle f} принимает в качестве аргументов простое число p{displaystyle p} и целое x{displaystyle x} в интервале от 0{displaystyle 0} до p−1{displaystyle p-1} и возвращает остаток от деления некоторого Ax{displaystyle A^{x}} на p{displaystyle p}. Эта функция может быть легко вычислена за время O{displaystyle O}(n3){displaystyle (n^{3})}, где n{displaystyle n} — количество битов в p{displaystyle p}. Обращение этой функции требует вычисления дискретного логарифма по модулю p{displaystyle p}. Пусть (G,∗){displaystyle (G,*)} - конечная абелева группа, например мультипликативная группа конечного поля или эллиптическая кривая над конечным полем. Задача вычисления дискретных логарифмов состоит в определении целого числа x{displaystyle x}, которое при данных A,B{displaystyle A,B} удовлетворяет соотношению:
- Ax=B{displaystyle A^{x}=B}
Для некоторых групп G{displaystyle G} такая задача довольно проста. Например, если G{displaystyle G} - группа целых чисел по модулю N{displaystyle N} по сложению. Для других групп, однако, эта задача более сложная. Например, в мультипликативной группе конечного поля, наилучший из известных алгоритмов, решающий задачу дискретного логарифмирования, - это метод квадратичного решета в числовом поле. Сложность вычисления дискретных логарифмов в этом случае оценивается как LN(1/3,c){displaystyle L_{N}(1/3,c)}. Схема Эль-Гамаля основывается на этой задаче[6].
Для групп, подобных эллиптической кривой, задача дискретного логарифмирования еще более трудна. Наилучший из доступных на сегодняшний день методов, вычисляющих дискретные логарифмы над общей эллиптической кривой над полем Fq{displaystyle mathbb {F} _{q}}, называется ρ-метод Полларда. Его сложность O(LN(1,1/2)){displaystyle O(L_{N}(1,1/2))}. Это экспоненциальный алгоритм, поэтому криптосистемы, основанные на эллиптической кривой, как правило, работают с малым ключом, около 160 бит. В то время как системы, отталкивающиеся от разложения на множители или вычисления дискретных логарифмов в конечных полях, используют ключи в 1024 бита[6].
С задачей дискретного логарифмирования так же связано несколько близких задач. Пусть дана конечная абелева группа (G,∗){displaystyle (G,*)}:
Задача Диффи-Хеллмана, которая состоит в следующем: даны элементы A∈G,B=Ax,C=Ay{displaystyle Ain G,B=A^{x},C=A^{y}}. Требуется вычислить D=Axy{displaystyle D=A^{xy}}.
Задача выбора Диффи-Хеллмана. Дано: A∈G,B=Ax,C=Ay,D=Az{displaystyle Ain G,B=A^{x},C=A^{y},D=A^{z}}. Требуется определить, является ли z{displaystyle z} произведением x{displaystyle x} и y{displaystyle y}.
Можно показать, что задача выбора Диффи-Хеллмана не сложнее задачи Диффи-Хеллмана, а задача Диффи-Хеллмана не сложнее задачи вычисления дискретных логарифмов[6].
Криптографические хеш-функции |
Существует множество криптографических хеш-функций (например, SHA-256), которые быстро вычисляются. Некоторые из более простых версий не проходили сложный анализ, но самые сильные версии продолжают предлагать быстрые практические решения для односторонних вычислений. Большая часть теоретической поддержки этих функций направлена на срыв некоторых из ранее проведенных успешных атак.
Другие претенденты |
Другие претенденты в односторонние функции основываются на сложности декодирования случайных линейных кодов и иных задачах.
См. также |
- Криптографическая хеш-функция
- Односторонняя функция с потайным входом
Примечания |
↑ 12 Птицын, 2002, с. 38-39.
↑ Схема аутентификации.
↑ Hashcash - A Denial of Service Counter-Measure (2002)
↑ Russell Impagliazzo, Steven Rudich. Private Information Retrieval Does Not Imply One-way Permutations.
↑ 12 Смарт, 2005, с. 185-186.
↑ 123 Смарт, 2005, с. 187-188.
Ссылки |
- Oded Goldreich. Volume 1, Basic Tools // Foundations of Cryptography. — Cambridge University Press, 2001. — ISBN 0-521-79172-3.
- Jonathan Katz, Yehuda Lindell. Introduction to Modern Cryptography. — CRC Press, 2007. — ISBN 1-58488-551-3.
- Michael Sipser. Section 10.6.3: One-way functions // Introduction to the Theory of Computation. — PWS Publishing, 1997. — P. 374—376. — ISBN 0-534-94728-X.
- Christos Papadimitriou. Section 12.1: One-way functions // Computational Complexity. — 1st edition. — Addison Wesley, 1993. — P. 279—298. — ISBN 0-201-53082-1.
- Глава 2.3. Односторонние функции // Введение в криптографию / Под ред. В. В. Ященко.
Глава 2.5.2 Односторонняя функция // Приложение теории детерминированного хаоса в криптографии / Птицын Н. — 2002. (недоступная ссылка)
- Глава 7.2 Односторонние функции // Криптография / Смарт Н. — 2005. — ISBN 5-94836-043-1.
- Глава 4.1 Односторонние функции (рус.) ?. Проверено 9 октября 2014.