コンテンツにスキップ

英文维基 | 中文维基 | 日文维基 | 草榴社区

利用者:Roget/試訳/Cramer-Shoup暗号

Cramer-Shoup cryptosystem (13:33, 1 November 2008)

Cramer-Shoup暗号とは標準モデルで適切な仮定のもIND-CCA2安全が示された初めての「効率の良い」公開鍵暗号である。 安全性はDDH仮定に基づいている。 1998年にとによって提案された。1998年版はElGamal暗号の拡張である。 ElGamal暗号は頑健性を持たないが、Cramer-Shoup暗号は別の要素を加えることによりより強力な敵に対しても頑健性を達成している。 頑健性はハッシュ関数の利用とElGamal暗号にはない計算によって得られている。 そのため、暗号文はElGamal暗号の2倍長い。

概要

[編集]

CramerとShoupによって示された安全性は、正確にいえば適応的選択暗号文攻撃の元での識別不可能性 (IND-CCA2) である。 公開鍵暗号の安全性要件の中では現在最も強い要件である。 攻撃者は復号オラクル(暗号方式の秘密鍵を持ち暗号文を復号できるオラクル)にアクセスできる。 「適応的」とは、攻撃者が攻撃者が攻撃の対象とする暗号文を知る前にも後にも復号オラクルを使用可能である、ということを意味している。(攻撃な対象となる暗号文をそのまま復号オラクルに問い合わせることは禁止されている。) より弱い安全性の定義は非適応的選択暗号文攻撃 (IND-CCA1) である。この場合、対象となる暗号文を知る前にのみ復号オラクルを使用可能である。

このような攻撃者に対しては広くつかわれている暗号が安全でないことは、かつてより知られていた。システム設計者は、このような攻撃は非現実的であり理論的興味に過ぎないと考えていた。 1990年代後半より、特にがRSA暗号を用いたSSLに対する現実的な適応的選択暗号文攻撃を示して以来、変化が起きている。

Cramer-Shoup暗号が初めてのIND-CCA2安全な暗号というわけではない。 NaorとYung、RackoffとSimon、DolevとDworkとNaorが、IND-CPA安全な暗号をIND-CCA1安全やIND-CCA2安全な暗号に変換する方法を提案している。 これらの方法は標準的な仮定の下(ランダムオラクル無しに)安全である。しかし、複雑なゼロ知識証明のテクニックを用いており、暗号化コストは大きく、暗号文の長さが長い。 他のアプローチとしては、やによるOAEP、また、藤崎-岡本変換が知られている。これらは効率の良い構成であるが、ハッシュ関数を理想化したランダムオラクルを用いている。 現実にこの変換を用いる場合にはランダムオラクルを他の実用的な関数(暗号学的なハッシュ関数)で置き換えなければならない。 研究が進むにつれ、この種のアプローチは安全でないと考えられている。(このアプローチを用いた現実的な暗号方式に対して、効率の良い攻撃が実証されているわけではない。)

暗号方式

[編集]

鍵生成、暗号化、復号について説明する。

鍵生成

[編集]
  • 位数の巡回群の記述と、その生成元を生成する。
  • 5つのランダムな値 からランダムに選ぶ。
  • を計算する。
  • 公開鍵はの記述である。秘密鍵はである。

暗号化

[編集]

平文を公開鍵で暗号化する。

  • の要素に変換する。
  • からランダムに選び、以下を計算する。
    • , ただし、H()は衝突耐性を持つハッシュ関数である。
  • 暗号文はである。

復号

[編集]

暗号文を秘密鍵で復号する。

  • まずを計算し、が成立するかを確かめる。もしこのテストが失敗した場合、復号を止め拒否する。
  • テストが成功した場合、を計算し、を出力する。

, and より、正しい暗号文であれば、正しく復号される。

もし、取りうる平文空間がの位数よりも大きい場合には、メッセージを分割し、それぞれを暗号化する。 また、効率良く暗号化するために、ハイブリッド暗号の中で使われることもある。

参考文献

[編集]

関連項目

[編集]

Category:暗号技術