WikiDer > Бесспорная подпись

Undeniable signature

An неоспоримая подпись это цифровой подписи схема, которая позволяет подписавшему быть избирательным, кому они позволяют проверять подписи. Схема добавляет явный отказ от подписи, предотвращая последующий отказ подписывающей стороны проверить подпись путем бездействия; ситуация, которая обесценила бы подпись в глазах проверяющего. Это было изобретено Дэвид Чаум и Ханс ван Антверпен в 1989 году.[1]

Обзор

В этой схеме подписывающий, обладающий закрытым ключом, может опубликовать подпись сообщения. Однако подпись ничего не раскрывает получателю / верификатору сообщения и подписи без участия в одном из двух интерактивных протоколов:

  • Протокол подтверждения, который подтверждает, что кандидат является действительной подписью сообщения, выданного подписывающим лицом, идентифицированным открытым ключом.
  • Протокол отклонения, который подтверждает, что кандидат не является действительной подписью сообщения, выданного подписавшим.

Мотивация схемы состоит в том, чтобы позволить подписывающей стороне выбирать, кому проверять подписи. Однако то, что подписывающая сторона может заявить, что подпись недействительна в любой более поздний момент, отказавшись участвовать в проверке, обесценит подписи для проверяющих. Протокол об отказе от отцовства различает эти случаи, удаляя правдоподобное отрицание подписавшейся стороны.

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

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

Протокол с нулевым разглашением

Следующий протокол был предложен Дэвид Чаум.[2]

Группа, грамм, выбирается, в котором задача дискретного логарифмирования неразрешима, и все операции в схеме происходят в этой группе. Обычно это будет конечная циклическая группа порядка п содержалась в Z/пZ, с п будучи большим простое число; эта группа снабжена групповой операцией целочисленного умножения по модулю п. Произвольный примитивный элемент (или генератор), грамм, из грамм выбран; вычисленные мощности грамм затем объедините, подчиняясь фиксированным аксиомам.

Алиса генерирует пару ключей, случайным образом выбирает закрытый ключ, Икс, а затем извлекает и публикует открытый ключ, у = гИкс.

Подпись сообщения

  1. Алиса подписывает сообщение, м, вычислив и опубликовав подпись, г = мИкс.

Протокол подтверждения (т. Е. Признания)

Боб хочет проверить подпись, z, из м Алиса под ключ, у.

  1. Боб выбирает два случайных числа: а и б, и использует их, чтобы скрыть сообщение, отправляя Алисе:
    с = маграммб.
  2. Алиса выбирает случайное число, q, использует его, чтобы ослепить, c, а затем подписав это, используя свой закрытый ключ, Икс, отправив Бобу:
    s1 = cgq и
    s2 = s1Икс.
    Обратите внимание, что
    s1Икс = (cgq)Икс = аграммб)Иксграммqx = Икс)а(граммИкс)б + д = zауб + д.
  3. Боб раскрывает а и б.
  4. Алиса проверяет, что а и б являются правильными слепыми значениями, то, если да, обнаруживает q. Открытие этих блайндов делает биржу нулевой информацией.
  5. Боб проверяет s1 = cgq, доказывая q не был выбран нечестно, и
    s2 = zауб + д,
    доказывает, что z - действительная подпись, выданная ключом Алисы. Обратите внимание, что
    zауб + д = Икс)а(граммИкс)б + д.

Алиса может обмануть на шаге 2, пытаясь случайным образом угадать s2.

Протокол отказа

Алиса хочет убедить Боба, что z не является действительной подписью м под ключ, граммИкс; т.е. г мИкс. Алиса и Боб согласовали целое число, k, который устанавливает вычислительную нагрузку на Алису и вероятность того, что она случайно добьется успеха.

  1. Боб выбирает случайные значения, s ∈ {0, 1, ..., k} и а, и отправляет:
    v1 = мsграмма и
    v2 = zsуа,
    где возведение в степень а используется, чтобы скрыть отправленные значения. Обратите внимание, что
    v2 = zsуа = Икс)s(граммИкс)а = v1Икс.
  2. Алиса, используя свой закрытый ключ, вычисляет v1Икс а затем частное,
    v1Иксv2−1 = sграмма)Иксsграммха)−1 = мsxz−s = Иксz−1)s.
    Таким образом, v1Иксv2−1 = 1, если только zмИкс.
  3. Затем Алиса проверяет v1Иксv2−1 для равенства по значениям:
    Иксz−1)я за i ∈ {0, 1,…, k};
    которые вычисляются путем многократного умножения мИксz−1 (а не возведением в степень для каждого я). Если тест проходит успешно, Алиса делает предположение о соответствующем я быть s; в противном случае она предполагает случайное значение. Где z = мИкс, Иксz−1)я = v1Иксv2−1 = 1 для всех я, s не подлежит восстановлению.
  4. Алиса обязуется я: она выбирает случайный р и отправляет хэш (г, я) Бобу.
  5. Боб раскрывает а.
  6. Алиса подтверждает, что а является правильным слепым (т.е. v1 и v2 может быть сгенерирован с его помощью), то, если да, то обнаруживает р. Открытие этих блайндов делает биржу нулевой информацией.
  7. Боб проверяет хэш (г, я) = хэш (r, s), доказывая, что Алиса знает s, следовательно zмИкс.

Если Алиса попытается обмануть на шаге 3, угадав s случайным образом вероятность успеха равна 1 / (к + 1). Так что если к = 1023 и протокол проводится десять раз, ее шансы 1 к 2100.

Смотрите также

Рекомендации

  1. ^ Чаум, Дэвид; ван Антверпен, Ганс (1990). «Бесспорные подписи». LNCS. 435: 212–216.
  2. ^ Чаум, Дэвид (1991). «Неоспоримые подписи с нулевым разглашением». Достижения в криптологии Труды EUROCRYPT '90: 458–462.