Funció de compressió unidireccional

és una funció que transforma dues entrades de longitud fixa en una sortida de longitud fixa.

En criptografia, una funció de compressió unidireccional és una funció que transforma dues entrades de longitud fixa en una sortida de longitud fixa.[1] La transformació és "unidireccional", el que significa que és difícil, donada una sortida determinada, calcular entrades que es comprimeixen a aquesta sortida. Les funcions de compressió unidireccionals no estan relacionades amb els algorismes de compressió de dades convencionals, que en canvi es poden invertir exactament (compressió sense pèrdues) o aproximadament (compressió amb pèrdues) a les dades originals.[2]

Una funció de compressió unidireccional.

Les funcions de compressió unidireccionals s'utilitzen, per exemple, en la construcció Merkle–Damgård dins de les funcions hash criptogràfiques.

Les funcions de compressió unidireccionals sovint es construeixen a partir de xifratge de blocs. Alguns mètodes per convertir qualsevol xifratge de bloc normal en una funció de compressió unidireccional són Davies–Meyer, Matyas–Meyer–Oseas, Miyaguchi–Preneel (funcions de compressió d'un sol bloc) i MDC-2/Meyer–Schilling, MDC-4., Hirose (funcions de compressió de doble longitud de bloc). Aquests mètodes es descriuen amb detall més avall. (MDC-2 també és el nom d'una funció hash patentada per IBM).[3]

Una funció de compressió barreja dues entrades de longitud fixa i produeix una única sortida de longitud fixa de la mateixa mida que una de les entrades. Això també es pot veure com que la funció de compressió transforma una entrada gran de longitud fixa en una sortida més curta i de longitud fixa.

Una funció unidireccional és una funció que és fàcil de calcular però difícil d'invertir. Una funció de compressió unidireccional (també anomenada funció hash) hauria de tenir les propietats següents: [4]

  • Fàcil de calcular: si teniu algunes entrades, és fàcil calcular la sortida.
  • Resistència a la preimatge: si un atacant només coneix la sortida, hauria de ser inviable calcular una entrada. En altres paraules, donada una sortida , hauria de ser inviable calcular una entrada de tal manera que .
  • Resistència de la segona preimatge: donada una entrada la sortida del qual és , hauria de ser inviable trobar una altra entrada que té la mateixa sortida , és a dir .
  • Resistència a la col·lisió: hauria de ser difícil trobar dues entrades diferents que es comprimeixin a la mateixa sortida, és a dir, un atacant no hauria de poder trobar un parell de missatges. de tal manera que . A causa de la paradoxa de l'aniversari (vegeu també atac d'aniversari) hi ha un 50% de possibilitats que es pugui trobar una col·lisió en un temps d'aproximadament on és el nombre de bits a la sortida de la funció hash. Per tant, un atac a la funció hash no hauria de ser capaç de trobar una col·lisió amb menys d'aproximadament treball.

Referències modifica

  1. Handbook of Applied Cryptography by Alfred J. Menezes, Paul C. van Oorschot, Scott A. Vanstone. Fifth Printing (August 2001) page 328.
  2. «One-way Compression Function - Miyaguchi–Preneel» (en anglès). /one-way_compression_function/miyaguchi. [Consulta: 2 febrer 2023].
  3. «What is the role of a compression function? – Wise-Answer» (en anglès). https://wise-answer.com.+[Consulta: 2 febrer 2023].
  4. «Crypto-IT» (en anglès). http://www.crypto-it.net.+[Consulta: 2 febrer 2023].