Rabin kriptosistema

Rabin kriptosistema yra viešo rakto kriptosistema. Ji buvo sukurta Michael O. Rabin.

Tai labai greita kriptosistema, kadangi šifravimui reikalauja vienos operacijos – kėlimo kvadratu moduliu . Saugumas remiasi skaičiaus skaidymo į du pirminius , kad problemos sudėtingumu.

Raktų parinkimo algoritmas

pasirenka du didelius pirminius skaičius ir sudaugina juos . viešas raktas

,

o privatus:

Šifravimas/dešifravimas

Tarkime, kad nori perduoti pranešimą , . turi viešą raktą – .

užšifruoja , tiesiog pakėlus jį kvadratu moduliu :

dešifruoja pranešimą, suradus šaknys moduliu . nusprendžia, kuris iš yra pranešimas.

Kvadratinė šaknis moduliu

Apibrėžimas. Simboliu žymėsime aibę skaičių .

Apibrėžimas. Simboliu žymėsime aibę skaičių . Jeigu – pirminis, tai

Apibrėžimas. Tegu – skaičius, o – pirminis skaičius. Legendre simbolis apibrėžiamas taip:

Čia ir apibrėžtos taip:

Bendras algoritmas kvadratinėm šaknims surasti:

ALGORITMAS SQR1
ĮVESTIS:  - skaičius,  - pirminis skaičius, 
IŠVESTIS: dvi šaknis skaičiaus  moduliu , jeigu jos egzistuoja
 1. Jeigu  – šaknų nėra.
 2. Parinkti , , kad 
 3. Užrašyti skaičių ,  – nelyginis.
 4. Apskaičiuoti 
 5. 
 6. Visiem  nuo  iki :
   6.1. 
   6.2. Jeigu, , tada 
   6.3. 
 7. Sprendimas: 

Jeigu , tai naudojamas sekantis algoritmas:

ALGORITMAS SQR2
ĮVESTIS:  - skaičius,  - pirminis skaičius, 
IŠVESTIS: dvi šaknys skaičiaus  moduliu , jeigu jos egzistuoja
 1. 
 2. 

Taikymas šio algoritmo (SQR2) Rabin kriptosistemos atveju atrodo taip:

Jeigu  ir Jeigu , tada
 1. Surasti  ir , kad .
 2. 
 3.  
 4. 
 5. 
 6. Rezultatas: 

Pastaba: ir moduliu n.

Jeigu – pirminis, tai skaičiaus moduliu šaknys surasime algoritmo SQR3 pagalba:

ALGORITMAS SQR3
ĮVESTIS:  - skaičius,  - pirminis skaičius, 
IŠVESTIS: dvi šaknys skaičiaus  moduliu , jeigu jos egzistuoja
 1. Pasirenkame , kad 
 2. Tegu  yra polinomas 
 3. 
 4. Rezultatas: 

Polinomų žiedas

Rabin kriptosistemos atveju algoritmas SQR3 panaudojamas taip:

ALGORITMAS SQR4
ĮVESTIS:  - skaičius, ,  ir  pirminiai
IŠVESTIS: keturios šaknys skaičiaus  moduliu , jeigu jos egzistuoja
 1. Naudojant SQR3, surandame skaičiaus  šaknys  moduliu 
 2. Naudojant SQR3, surandame skaičiaus  šaknys  moduliu 
 3. Surandame  ir , kad 
 4. , 
 5. Rezultatas: , visi moduliu 

Literatūra

  • A. Menezes, P. van Oorschot, S. Vanstone, 1996, Handbook of Applied Cryptography

Kitos viešo rakto kriptosistemos