Poly1305

codi d'autenticació de missatges criptogràfics (MAC) creat per Daniel J. Bernstein

Poly1305 és una família de hash universal dissenyada per Daniel J. Bernstein per utilitzar-la en criptografia.[1]

Xifratge ChaCha20-Poly1305

Com amb qualsevol família de hash universal, Poly1305 es pot utilitzar com a codi d'autenticació de missatges d'una sola vegada per autenticar un missatge únic mitjançant una clau secreta compartida entre remitent i destinatari, [2] de manera similar a com es pot utilitzar un bloc d'un sol ús. per ocultar el contingut d'un sol missatge mitjançant una clau secreta compartida entre remitent i destinatari.

Originalment, Poly1305 es va proposar com a part de Poly1305-AES, un autenticador Carter – Wegman [3][4][5] que combina el hash Poly1305 amb AES-128 per autenticar molts missatges mitjançant una única clau curta i números de missatge diferents. Poly1305 es va aplicar posteriorment amb una clau d'un sol ús generada per a cada missatge mitjançant XSalsa20 al xifratge autenticat NaCl crypto_secretbox_xsalsa20poly1305, i després utilitzant ChaCha al xifratge autenticat ChaCha20-Poly1305 [5] desplegat en TLS. l'internet.

Descripció modifica

Definició de Poly1305 modifica

Poly1305 pren una clau secreta de 16 bytes   i un   missatge -byte   i retorna un hash de 16 bytes  . Per fer-ho, Poly1305: [6]

  1. Interpreta com un nombre enter de 16 bytes little-endian.
  2. Trenca el missatge en fragments consecutius de 16 bytes.
  3. Interpreta els fragments de 16 bytes com a nombres enters little-endians de 17 bytes afegint un 1 byte a cada fragment de 16 bytes, per utilitzar-los com a coeficients d'un polinomi.
  4. Avalua el polinomi en el punt mòdul el primer.
  5. Redueix el mòdul del resultat codificat en little-endian retorna un hash de 16 bytes.

Els coeficients   del polinomi  , on  , són:

 
amb l'excepció que, si  , llavors:

 

La clau secreta   està restringit a tenir els bytes  , és a dir, tenir els seus quatre bits principals clars; i tenir els bytes  , és a dir, per tenir els seus dos bits inferiors clars. Així n'hi ha   diferents valors possibles de  .

Seguretat modifica

La seguretat de Poly1305 i els seus derivats contra la falsificació es deu a la seva probabilitat de diferència limitada com a família hash universal : si   i   són missatges de fins a   bytes cadascun, i   és qualsevol cadena de 16 bytes interpretada com un nombre enter little-endian, doncs

 
on   és una clau aleatòria Poly1305 uniforme.  : Teorema 3.3, pàg. 8 

Aquesta propietat de vegades s'anomena   -quasi-Δ-universalitat acabada  , o   -AΔU, on   en aquest cas.

Referències modifica

  1. Aumasson, Jean-Philippe. «Chapter 7: Keyed Hashing». A: Serious Cryptography: A Practical Introduction to Modern Encryption (en anglès). No Starch Press, 2018, p. 136–138. ISBN 978-1-59327-826-7. 
  2. Bernstein, Daniel J. «Protecting communications against forgery». A: Buhler. Algorithmic number theory: lattices, number fields, curves and cryptography (en anglès). 44. Cambridge University Press, 2008-05-01, p. 535–549 (Mathematical Sciences Research Institute Publications). ISBN 978-0521808545. 
  3. Journal of Computer and System Sciences, 22, 3, 1981, pàg. 265–279. DOI: 10.1016/0022-0000(81)90033-7.
  4. Boneh, Dan. A Graduate Course in Applied Cryptography (en anglès). Version 0.5, January 2020. 
  5. 5,0 5,1 Aumasson, Jean-Philippe. «Chapter 7: Keyed Hashing». A: Serious Cryptography: A Practical Introduction to Modern Encryption (en anglès). No Starch Press, 2018, p. 136–138. ISBN 978-1-59327-826-7. 
  6. Aumasson, Jean-Philippe. «Chapter 7: Keyed Hashing». A: Serious Cryptography: A Practical Introduction to Modern Encryption (en anglès). No Starch Press, 2018, p. 136–138. ISBN 978-1-59327-826-7.