Научная статья на тему 'Реализация протокола коллективной подписина основе стандартов ЭЦП'

Реализация протокола коллективной подписина основе стандартов ЭЦП Текст научной статьи по специальности «Компьютерные и информационные науки»

CC BY
849
168
i Надоели баннеры? Вы всегда можете отключить рекламу.
Ключевые слова
ЦИФРОВАЯ ПОДПИСЬ / DIGITAL SIGNATURE / КОЛЛЕКТИВНАЯ ПОДПИСЬ / COLLECTIVE SIGNATURE / КРИПТОГРАФИЧЕСКИЕ ПРОТОКОЛЫ / CRYPTOGRAPHIC PROTOCOL

Аннотация научной статьи по компьютерным и информационным наукам, автор научной работы — Ананьев М. Ю., Гортинская Л. В., Костин А. А., Молдовян Н. А.

Рассматривается обобщенный протокол формирования коллективной электронной цифровой подписи, основанный на выполнении процедур "свертки" индивидуальных параметров, вырабатываемых отдельными пользователями в зависимости от подписываемого документа и своих секретных ключей. Протоколобеспечивает одновременность формирования подписи и использует стандартную инфраструктуру открытых ключей. Сформулированы основные требованияи рассмотрен вопрос создания протоколов коллективной электронной цифровой подписи на основе российских стандартов ЭЦП 1994 и 2001 гг.

i Надоели баннеры? Вы всегда можете отключить рекламу.

Похожие темы научных работ по компьютерным и информационным наукам , автор научной работы — Ананьев М. Ю., Гортинская Л. В., Костин А. А., Молдовян Н. А.

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

REALIZATION OF COLLECTIVE SIGNATURE PROTOCOL ON THE BASIS OF STANDARDSFOR DIGITAL SIGNATURE

The paper considers the collective digital signature protocol based on computing a digest of the individualparameters produced by users in dependence on the message and their private keys. The protocol providessimultaneous process of the signature generation and uses the standard public key infrastructure. There areformulated the main requirements to the protocol and considered implementation of the protocol using theRussian standards for digital signatures GOST R 34.10-94 and GOST R 34.10-2001.

Текст научной работы на тему «Реализация протокола коллективной подписина основе стандартов ЭЦП»

ВЫЧИСЛИТЕЛЬНАЯ ТЕХНИКА

УДК 681.3

М. Ю. Ананьев, Л. В. Гортинская, А. А. Костин, Н. А. Молдовян

РЕАЛИЗАЦИЯ ПРОТОКОЛА КОЛЛЕКТИВНОЙ ПОДПИСИ НА ОСНОВЕ СТАНДАРТОВ ЭЦП

Рассматривается обобщенный протокол формирования коллективной электронной цифровой подписи, основанный на выполнении процедур „свертки" индивидуальных параметров, вырабатываемых отдельными пользователями в зависимости от подписываемого документа и своих секретных ключей. Протокол обеспечивает одновременность формирования подписи и использует стандартную инфраструктуру открытых ключей. Сформулированы основные требования и рассмотрен вопрос создания протоколов коллективной электронной цифровой подписи на основе российских стандартов ЭЦП 1994 и 2001 гг.

Ключевые слова: цифровая подпись, коллективная подпись, криптографические протоколы.

Введение. В технологиях электронного документооборота широко используются алгоритмы электронной цифровой подписи (ЭЦП), на основе которых в сочетании с нормативно-правовыми механизмами обеспечивается придание юридической силы электронной документации [1, 2]. При разработке разнообразных коллективных проектов важной проблемой является создание протоколов, обеспечивающих реализацию коллективной (или кратной) ЭЦП [3].

Изложенные в работе [3] подходы к решению этой задачи на основе генерации совокупности ЭЦП, принадлежащей отдельным пользователям, имеют следующие недостатки:

— необходимость использования дополнительных процедур проверки целостности коллективной ЭЦП (КЭЦП), которые позволяют проверить ее полноту, т.е. обнаружить попытки формирования КЭЦП, принадлежащей измененному числу пользователей;

— увеличение размера КЭЦП пропорционально числу подписавших документ участников (размер ЭЦП особенно важен при необходимости ее записи в виде штрих-кода на бумажных носителях).

Для устранения указанных недостатков был предложен [4] новый способ формирования и проверки подлинности КЭЦП, использующий понятие общего (коллективного) открытого ключа, формируемого на основе данных, имеющихся в стандартных справочниках открытых ключей.

В настоящей статье рассматриваются вопросы применения предложенной в работе [4] обобщенной схемы формирования КЭЦП с использованием коллективного открытого ключа и вопросы ее реализации на основе процедур генерации и проверки ЭЦП, регламентируемых стандартами ЭЦП — ГОСТ Р 34.10-94 и ГОСТ Р 34.10-2007 [5, 6].

Концепция коллективной подписи. Поставлена задача построить протокол формирования и проверки подписи следующим образом: ЭЦП обычного размера должна подтверждать то, что некоторый электронный документ подписан каждым пользователем из некото-

рого заданного множества пользователей. При этом приняты следующие дополнительные требования к разрабатываемому протоколу КЭЦП:

— целостность — из КЭЦП нельзя вычислить правильную подпись, соответствующую другому подмножеству пользователей;

— независимость от пользователей — КЭЦП может сформировать любая группа пользователей, независимо от их числа и состава;

— одновременность генерации КЭЦП — все значения, возникающие на промежуточных этапах процедуры генерации КЭЦП, не должны быть правильными подписями к каким-либо сообщениям;

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

В качестве базовой идеи протокола коллективной подписи была принята концепция использования коллективного открытого ключа, являющегося функцией открытых ключей пользователей. Коллективный открытый ключ некоторой произвольно задаваемой совокупности m пользователей, каждый из которых является владельцем соответствующего открытого ключа из множества y1, y2, ym, представляет собой некоторое значение y = f(y1, y2, ..., ym).

Общая схема формирования КЭЦП была реализована в виде удовлетворяющих перечисленным требованиям конкретных алгоритмов и протоколов с использованием следующих трудных вычислительных задач:

— извлечение корней большой простой степени по большому простому модулю;

— дискретное логарифмирование в мультипликативной группе большого простого порядка;

— дискретное логарифмирование в группе точек эллиптической кривой специального вида.

Особый интерес представляют алгоритмы, основанные на последней из перечисленных

трудных задач, поскольку в этом случае обеспечивается наибольшая производительность процедур генерации и проверки подписи. Достоинство предложенной концепции КЭЦП заключается в использовании стандартной инфраструктуры открытых ключей.

Обратимся, далее, к реализации протоколов КЭЦП, основанной на проверочных уравнениях, предлагаемых стандартами ЭЦП.

Реализация протоколов на основе стандартов ЭЦП.

I. Стандарт ЭЦП — ГОСТ Р 34.10-94 [5] — регламентирует использование простого числа p, такого что 510 < p < 512 бит либо 1022 < p < 1024 бит, где p — разрядность p в двоичном представлении, при этом число p - 1 содержит большой простой делитель:

255 256 511 512

2 < q < 2 либо 2 < q < 2 соответственно. Специфицируемые алгоритмы генерации и проверки ЭЦП используют число а ^ 1, такое что a q mod p = 1, где а — генератор подгруппы достаточно большого простого порядка q. Вычисление ЭЦП осуществляется следующим образом.

1. Генерируется случайное число к, 1 < к < q.

2. Вычисляется значение R = (а к mod p) mod q, являющееся первой частью подписи.

3. По ГОСТ Р 34.11-94 вычисляется хэш-функция H от подписываемого сообщения.

4. Вычисляется вторая часть подписи: S = кН + zR mod q, где z — секретный ключ. Если S = 0, процедура генерации подписи повторяется.

Процедура проверки подлинности ЭЦП содержит следующие шаги.

1. Поверяется выполнение условий r < q и s < q, если они не выполняются, то подпись недействительна.

2. Вычисляется значение

R' = (aS'HyR'Н mod p)mod q, (1)

где у — открытый ключ пользователя, сформировавшего проверяемую подпись.

3. Сравниваются значения R и R '. Если R = R, то подпись признается действительной.

Протокол КЭЦП реализуется следующим образом. Каждый i-й пользователь формирует

zi

открытый ключ видаyi = a modp, где zi — личный (секретный) ключ, i = 1, 2, ..., m. Коллективным открытым ключом является произведение

y = У\У2УуУш mod p.

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

ki

разовый случайный секретный ключ — число ki, затем вычисляет Ri = (a mod p) mod q и предоставляет это значение для коллективного использования. Далее вычисляется произведение

R = R1R2R3 -Rm mod q. Затем каждый пользователь по определенному им значению Ri и величине H вычисляет свою часть подписи

Si = kiH + ziR mod q .

Коллективной подписью является пара чисел (R, S), где S вычисляется по формуле

S = S1 + S2 + S3 +.+ Sm mod q. Проверка коллективной подписи осуществляется по формуле (1). Если R = R' то КЭЦП совокупности т пользователей является подлинной, так как она могла быть сформирована только при участии каждого пользователя из этой группы, поскольку для ее формирования требуется использование секретного ключа каждого из них. Отметим, что аутентификация значений Ri осуществляется автоматически при проверке подлинности коллективной ЭЦП. Если нарушитель попытается подменить какое-либо из этих значений или заменить на ранее использованные значения, то факт вмешательства в протокол будет сразу же выявлен при проверке подлинности ЭЦП, т. е. будет получено R' ^ R. Очевидно, что размер КЭЦП не зависит от m.

Покажем корректность предложенного алгоритма КЭЦП. Подставив подпись (R, S), где

S / H R / H

S = ESi modq и R = ПRi modq, в проверочное уравнение R = (a~' " y i=1 i=1 убеждаемся, что оно выполняется:

mod p) mod q,

R =

E S. / H

f

a

\

R / H

П y,

V i=1

mod p

f

mod q =

m

\

Па

V i=1

S /H П yiR/H mod p

i=1 J

m

П(

S, / H Z,R / H

a 1 a 1

,=1 m

k.,

mod p ) mod q =

mod q =

П

i=1

(k, - z,R)/ H z,R / H ,

а 1 1 ' a ' mod p

П(аki mod p)mod q

i=1

f

mod q =

\

П R,

V i=1

mod q = mod q = mod q.

Па i modp

V i=1

II. Стандарт ЭЦП — ГОСТ Р 34.10-2001 [6] — регламентирует использование: простого числа p — модуля эллиптической кривой (ЭК), которая задается в декартовой системе

2 3

координат уравнением у = x + ax + bmodp с коэффициентами a и b: a,b e GFp (GFp —

поле Галуа порядка р); простого числа q — порядка циклической подгруппы точек ЭК; точки G с координатами (Xg , yG), такой что точка G не совпадает с началом координат, а произведение qG — совпадает. Секретным ключом является достаточно большое целое число d, а открытым ключом — точка Q = dG. Формирование подписи (R, S) осуществляется в соответствии со следующим алгоритмом.

1. Генерируется случайное целое число k, 0 < k < q.

2. Вычисляются координаты точки ЭК C = kP и определяется значение R = xc mod q, где xC — координата точки С.

3. Вычисляется значение S = (Rd + ke) mod q, где e=H mod q. Подписью является пара чисел (R, S).

iНе можете найти то, что вам нужно? Попробуйте сервис подбора литературы.

Проверка подписи заключается в вычислении координат точки ЭК:

C = ((Se

1) mod q) G + ((q - R) e"1 mod q) Q,

(2)

а также в определении значения R' = xc mod q и проверке выполнения равенства R' = R.

Протокол КЭЦП реализуется следующим образом. Каждый i-й пользователь формирует открытый ключ вида Q = dfi, где di — личный (секретный) ключ, i = 1, 2, ..., m. Коллективным открытым ключом является сумма

Q = Qi + Q2 + Q3 + Qm.

Коллективная подпись формируется следующим путем. Каждый пользователь выбирает разовый случайный секретный ключ — число ki, затем вычисляет координаты точки Ci = kiG и предоставляет их для коллективного использования. Далее определяется сумма всех точек Ci:

C = Ci + C2 + Сз +.+ C m,

по которой вычисляется значение R. Затем каждый i-й пользователь по своему секретному ключу di, значению ki и величине e вычисляет свою часть подписи

Si = (Rdi + kte) mod q.

Коллективной подписью является пара чисел (R, S), где S вычисляется по формуле

S = S1 + S2 + S3 +.+ Sm mod q.

Проверка коллективной подписи осуществляется по проверочной формуле. Если R' = xc ' mod q = R, где координаты точки C 'вычисляются по соотношению (2), то КЭЦП совокупности m пользователей является подлинной, так как она могла быть сформирована только при участии каждого пользователя из этой группы, поскольку для ее формирования требуется использование секретного ключа каждого из них.

Генерация индивидуальных значений

Ri, •••, Rm

Секретные ключи

Xi

x2 _

->

В^гчисление коллективного рандомизирующего элемента ЭЦП R = fRi, Rm)

к

Формирование части S1

Формирование части S2 _р

*

... j

Формирование части Sm

Электронный

документ (представлен обычно значением хэш-функции Н)

Интеграция частей

SU Sm

в единую КЭЦП

КЭЦП: (R, S)

Рис. 1

Общая схема формирования коллективной подписи представлена на рис. 1, а процедура проверки подлинности КЭЦП — на рис. 2.

x 1

m

Справочник открытых ключей

У1

У2

Ут

Формирование коллективного открытого ключа у

Значение КЭЦП: (R, S)

ЗЕ

Проверка подлинности КЭЦП

Электронный документ

Да/Нет

Рис. 2

Заключение. Применение понятия коллективного открытого ключа позволяет построить протоколы КЭЦП, перспективные для практического применения в технологиях электронного документооборота благодаря обеспечению одновременности формирования подписи и ее целостности. Достоинством таких протоколов является возможность их практической реализации на основе стандартной инфраструктуры открытых ключей и стандартов ЭЦП. Использование КЭЦП является удачным решением известной проблемы одновременного подписания контракта [7]. Представляет интерес использование КЭЦП для построения протоколов „множественной подписи" [7], что составляет самостоятельную задачу дальнейшего развития протоколов на основе понятия коллективного открытого ключа.

Работа выполнена при поддержке Российского фонда фундаментальных исследований, грант № 08-07-90100-Мол_а.

список литературы

1. ВенбоМао. Современная криптография. Теория и практика. М. — СПб. — Киев: Изд. дом „Вильямс", 2005. 763 с.

2. Молдовян Н. А. Введение в криптосистемы с открытым ключом. СПб.: БХВ-Петербург, 2005. 286 с.

3. Min-Shiang Hawng, Cheng-Chi Lee. Research issues and challenges for multiple digital signature // Intern. J. of Network Security. 2005. Vol. 1, N 1. P. 1—7.

4. Способ генерации и проверки подлинности электронной цифровой подписи, заверяющей электронный документ / А. А. Молдовян, Н. А. Молдовян. Пат. заявка № 2007130982, РФ. Заявл. 13.08.2007.

5. ГОСТ Р 34.10-94. Информационная технология. Криптографическая защита информации. Процессы формирования и проверки электронной цифровой подписи. М.: Госстандарт Российской Федерации, 1994.

6. ГОСТ Р 34.10-2001. Информационная технология. Криптографическая защита информации. Процессы формирования и проверки электронной цифровой подписи. М.: Госстандарт России, 2001.

7. Schneier B. Applied Cryptography: Protocol, Algorithms, and Source Code. N. Y.: John Wiley & Sons, 1996. 758 p.

Михаил Юрьевич Ананьев Лидия Вячеславовна Гортинская

Андрей Алексеевич Костин

Николай Андреевич Молдовян

Рекомендована НИИ „Вектор"

Сведения об авторах аспирант; Санкт-Петербургский государственный университет водных коммуникаций; E-mail: [email protected]

канд. физ.-мат. наук; Научный филиал ФГУП НИИ „Вектор" — Специализированный центр программных систем „Спектр", Санкт-Петербург; E-mail: [email protected]

канд. техн. наук; Научный филиал ФГУП НИИ „Вектор" — Специализированный центр программных систем „Спектр", Санкт-Петербург; E-mail: [email protected]

д-р техн. наук; Научный филиал ФГУП НИИ „Вектор" — Специализированный центр программных систем „Спектр", Санкт-Петербург; E-mail: [email protected]

Поступила в редакцию 04.10.07 г.

i Надоели баннеры? Вы всегда можете отключить рекламу.