Goldwasser-Micali

Tähän artikkeliin tai osioon ei ole merkitty lähteitä, joten tiedot kannattaa tarkistaa muista tietolähteistä.
Voit auttaa Wikipediaa lisäämällä artikkeliin tarkistettavissa olevia lähteitä ja merkitsemällä ne ohjeen mukaan.

Goldwasser-Micali kryptosysteemi (GM) on epäsymmetrinen julkisen avaimen salaamisalgoritmi, jonka ovat kehittäneet Shafi Goldwasser ja Silvio Micali vuonna 1982. GM oli ensimmäinen satunnaistava (probabilistinen) julkisen avaimen salakirjoitusjärjestelmä, joka on kryptografisten standardioletusten ollessa voimassa todistettavasti turvallinen. Se ei kuitenkaan ole tehokas kryptosysteemi, koska salakielinen viesti voi olla alkuperäistä viestiä satoja kertoja pitempi. Todistaakseen kryptosysteemin turvallisuusominaisuudet Goldwasser ja Micali esittelivät laajaan käyttöön levinneen semanttisen turvallisuuden käsitteen.

GM salakirjoitusjärjestelmä on semanttisesti turvallinen olettaen, että ns. neliönjäännösprobleema on ratkeamaton modulo yhdistetty luku N = p q {\displaystyle N=pq} , missä p {\displaystyle p} ja q {\displaystyle q} ovat suuria alkulukuja. Olettamuksen mukaan annetuilla ( x , N ) {\displaystyle (x,N)} on hyvin vaikeata määrätä, onko jokin luku x {\displaystyle x} neliönjäännös modulo N {\displaystyle N} (ts. onko olemassa sellaista lukua y {\displaystyle y} , että x = y 2 {\displaystyle x=y^{2}} mod N {\displaystyle N} ), kun Jacobin symboli luvulle x {\displaystyle x} saa arvon +1. Neliönjäännösprobleema on helppo ratkaista, kun luvun N {\displaystyle N} tekijöihinjako tunnetaan. Toisaalta uusia neliönjäännöksiä pystyy kuka tahansa tuottamaan vaikka ei tuntisi tätä tekijöihinjakoa. GM-salakirjoitusjärjestelmä hyödyntää tätä epäsymmetriaa salakirjoittamalla tietyn selväkielisen viestin joko jonoksi neliönjäännöksiä tai epäneliöitä modulo N {\displaystyle N} , joilla kaikilla Jacobin symboli saa arvon +1. Viestin vastaanottaja käyttää tuntemaansa luvun N {\displaystyle N} tekijöihinjakoa salaisena avaimenaan ja desiferoi viestin testaamalla, ovatko vastaanotetun salakieliviestin luvut neliöitä vai epäneliöitä.

Koska Goldwasser-Micali korvaa jokaisen selväkielisen koodin bitin suuruusluokkaa | N | {\displaystyle |N|} olevalla luvulla, GM salaus johtaa koodin oleelliseen laajentumiseen. Tekijöihinjakoon perustuvien hyökkäysten estämiseksi suositellaan nimittäin, että luku N {\displaystyle N} olisi useiden satojen bittien mittainen. Siten järjestelmä epäkäytännöllisenä palvelee lähinnä teoreettista tutkimusta. Käytännön sovellutuksia varten on myöhemmin kehitetty tehokkaampia todistettavasti turvallisia salakirjoitusjärjestelmiä. Esimerkki tällaisesta järjestelmästä on Elgamal-järjestelmä.

Koska salauksessa käytetään satunnaistavaa algoritmia, sama selväkieliteksti tuottaa yleensä erilaisia salakieliviestejä joka salauskerralla. Tästä on järjestelmän turvallisuuden kannalta merkittävää etua, sillä se estää sen, että viestien sisältöä voitaisiin arvata vertailemalla salakieliviestejä aikaisemmin tunnettuihin.

Järjestelmän määrittely

Goldwasser-Micali koostuu kolmesta algoritmista:

  • satunnaistava avaimen generointialgoritmi, joka tuottaa julkisen ja salaisen avaimen,
  • satunnaistava salausalgoritmi ja
  • deterministinen purkualgoritmi.

Järjestelmä perustuu siihen, että pystytään päättelemään, onko annettu luku x {\displaystyle x} neliönjäännös mod N {\displaystyle N} , kun luvun N {\displaystyle N} tekijöihinjako ( p , q ) {\displaystyle (p,q)} tunnetaan. Jos nimittäin x ( p 1 ) / 2 1 {\displaystyle x^{(p-1)/2}\equiv 1} (mod p {\displaystyle p} ) ja x ( q 1 ) / 2 1 {\displaystyle x^{(q-1)/2}\equiv 1} (mod q {\displaystyle q} ), niin x {\displaystyle x} on neliönjäännös modulo N {\displaystyle N} , muussa tapauksessa kysymyksessä on epäneliö.

Avaimen generointi

GM-järjestelmän moduuliluku generoidaan samalla tavalla kuin RSA-järjestelmässä.

  1. Liisa generoi satunnaisesti ja toisistaan riippumatta kaksi sellaista suurta alkulukua p {\displaystyle p} ja q {\displaystyle q} , että p {\displaystyle p\neq } .
  2. Liisa laskee luvun N = p q {\displaystyle N=pq} .
  3. Tämän jälkeen hän etsii jonkin epäneliön z {\displaystyle z} modulo N {\displaystyle N} , jolle Jacobin symboli saa arvon +1. Tämän hän voi tehdä valitsemalla satunnaislukuja ja testaamalla tuntemansa tekijöihinjaon avulla, ovatko ne neliönjäännöksiä. Jos ( p , q ) 3 {\displaystyle (p,q)\equiv 3} (mod 4 {\displaystyle 4} ) (ts. N {\displaystyle N} on Blumin kokonaisluku), niin luvulla N 1 {\displaystyle N-1} on varmasti tämä ominaisuus.

Julkinen avain muodostuu lukuparista ( N , z ) {\displaystyle (N,z)} . Salaisen avaimen muodostaa puolestaan tekijöihinjako ( p , q ) {\displaystyle (p,q)} .

Viestin salaaminen

Oletetaan, että Roope haluaa lähettää Liisalle viestin m:

  1. Roope koodaa viestin m {\displaystyle m} bittijonoksi ( m 0 , m 1 , , m n ) {\displaystyle (m_{0},m_{1},\dots ,m_{n})} käyttäen jotain yksinkertaista ja tunnettua koodaustapaa, esimerkiksi ASCII-koodia.
  2. Jokaista bittiä m i {\displaystyle m_{i}} kohti Roope generoi satunnaisluvun y {\displaystyle y} , joka on pienempi kuin N {\displaystyle N} . Hän laskee arvon c i y y z m i {\displaystyle c_{i}\equiv y^{y}z^{m_{i}}} (mod N {\displaystyle N} ).

Roope lähettää Liisalle salakielisen viestin ( c 0 , c 1 , , c n ) {\displaystyle (c_{0},c_{1},\dots ,c_{n})} .

Viestin avaaminen

Liisa vastaanottaa salakieliviestin ( c 0 , c 1 , , c i ) {\displaystyle (c_{0},c_{1},\dots ,c_{i})} . Hän pystyy palauttamaan viestin m {\displaystyle m} seuraavalla tavalla:

  1. Käyttämällä tuntemaansa tekijöihinjakoa ( p , q ) {\displaystyle (p,q)} Liisa tutkii, mitkä salakieliviestin luvut c i {\displaystyle c_{i}} ovat neliönjäännöksiä. Jos luku c i {\displaystyle c_{i}} on neliönjäännös, m i = 1 {\displaystyle m_{i}=1} , muuten m i = 0 {\displaystyle m_{i}=0} .

Liisa saa näin selville selväkieliviestin m = ( m 0 , m 1 , , m n ) {\displaystyle m=(m_{0},m_{1},\dots ,m_{n})} .