ECDSA

ECDSA (anglicky Elliptic Curve Digital Signature Algorithm) je šifra s veřejným klíčem pro elektronický podpis, který využívá kryptografii nad eliptickými křivkami (jde o variantu šifry DSA). Využívá postkvantovou kryptografii pro zvýšení odolnosti proti prolomení šifry díky budoucím pokrokům v kryptoanalýze za pomoci kvantového počítače. ECDSA je nástupcem šifry RSA pro digitální certifikáty protokolu HTTPS (resp. TLS), který používají webové prohlížeče pro zabezpečený přístup k webovým stránkám. Na rozdíl od RSA je úspornější a rychlejší (méně výpočetně náročnější a stačí ji i kratší klíče).[1][2]

Digitální podepisování s využitím eliptických křivek

Vytváření podpisu

Pokud chce Alice poslat zprávu m Bobovi, musí se nejprve domluvit na parametrech (p,a,b,G,n,h), kde p je prvočíslo, kterým definujeme těleso, konstanty a, b z rovnice eliptické křivky, bod G na eliptické křivce, jeho řád n a kofaktor h, který udává podíl počtu prvků grupy bodů na eliptické křivce a řádu bodu G. Alice také musí mít své klíče vhodné pro kryptografii nad eliptickými křivkami skládající se ze soukromého klíče dA, veřejného klíče QA, kde dA je náhodně vybrané celé kladné číslo z intervalu [1;n-1], (viz sčítání bodů na eliptické křivce).

  • Alice náhodně zvolí k, .
  • Následně spočítá , kde . Pokud , musí Alice zvolit jiné k.
  • Zjistí hash zprávy h(m), spočítá .
  • Čísla r, s tvoří elektronický podpis.

Ověřování podpisu

Bob musí zjistit veřejný klíč Alice QA. Pokud má pochybnosti ohledně zdroje, musí si ověřit tento klíč.

Pokud vše platí, může Bob učinit následující kroky:

  • Ověří, že . Pokud nejsou, podpis je neplatný.
  • Bob zjistí hash zprávy h(m).
  • Spočítá .
  • Spočítá u1, u2, kde ; .
  • Následně spočítá souřadnice .
  • Podpis je platný, když .

Příklad

Vytváření podpisu

  • Alice zvolí prvočíslo , bod G[13;16], , řád .
  • Zvolí , QA[5;19], zvolí číslo .
  • Následně nalezne bod kG[17;3] (, zdvojnásobí tedy bod G, nalezne pomyslný bod R, který zdvojnásobí a získá hledaný bod), spočítá ; .
  • Zjistí hash zprávy h(m), (hash byl náhodně zvolen pro tento příklad), spočítá .
  • Čísla , tvoří elektronický podpis.

Ověřování podpisu

  • Bob ověřil klíč QA.
  • Nyní ověří, že , tedy že .
  • Bob zjistí hash zprávy h(m), (viz Alice).
  • Spočítá .
  • Spočítá u1, u2, kde ; .
  • Následně spočítá souřadnice .
  • Podpis je platný, když , , , podpis je platný.

Důkaz platnosti

  • , což lze upravit pomocí ekvivalentních úprav na
  • vynásobíme-li obě strany kongruence w, získáme
  • , , po dosazení získáváme
  • , z toho plyne, že , po dosazení získáváme
  • celou kongruenci vynásobíme bodem G, získáme (po drobné ekvivalentní úpravě) ,
  • , QED

Související články

Odkazy

Reference

  1. Srovnání ECDSA vs RSA: Jednoduchý průvodce [online]. [cit. 2025-02-06]. Dostupné online. 
  2. GRIGUTYTĖ, Monika. RSA vs. ECDSA: What are the differences?. nordvpn.com [online]. NordVPN, 2024-04-18 [cit. 2025-02-06]. Dostupné online. 

Související články