El cifrado totalmente homomórfico es un cifrado que permite que un texto cifrado dado π 1 ,…, π t cualquiera (no solo el titular de la clave) obtenga el texto cifrado de cualquier función deseada f( π 1 ,…, π t ) , siempre que esto función se puede calcular de manera efectiva.
La idea del cifrado totalmente homomórfico fue propuesta por primera vez en 1978 por los inventores del algoritmo criptográfico de clave pública RSA , Ronald Rivest y Adi Shamir , junto con Michael Dertouzos . [1] Sin embargo, en las etapas iniciales, los intentos de crear un criptosistema con dicho cifrado no tuvieron éxito. Durante muchos años no estuvo claro si la encriptación totalmente homomórfica era siquiera posible, aunque los intentos de crear un sistema de este tipo se hicieron repetidamente. Entonces, por ejemplo, el criptosistema propuesto en 1982 por Shafi Goldwasser y Silvio Micali tenía un nivel bastante alto de fuerza criptográfica, pero solo era parcialmente homomórfico (homomorfo solo además) y podía cifrar solo un bit. [2] En 1999, Pascal Peillet propuso otro sistema de cifrado homomórfico aditivo . [3] Un gran avance en el desarrollo del cifrado totalmente homomórfico se produjo en 2009, cuando Craig Gentry propuso por primera vez una variante de un criptosistema totalmente homomórfico basado en la criptografía de celosía. [4] Desde entonces han aparecido un gran número de trabajos que proponen una modificación del criptosistema Gentry con el fin de mejorar su rendimiento.
El cifrado completamente homomórfico es una primitiva criptográfica que es una función de cifrado que satisface el requisito adicional de homomorfismo con respecto a cualquier operación en textos sin formato. La función de cifrado , donde m es el texto plano, k es la clave de cifrado, es homomórfica con respecto a la operación sobre textos planos, si existe un algoritmo eficiente , que habiendo recibido cualquier par de criptogramas de la forma como entrada , produce un criptograma tal que al descifrar , se obtendrá el texto sin formato [5] . Un homomorfismo con respecto a la operación se define de manera similar .
Mientras que los criptosistemas parcialmente homomórficos son homomórficos en una sola operación de texto simple (ya sea suma o multiplicación), los sistemas completamente homomórficos admiten homomorfismo en ambas operaciones (tanto suma como multiplicación) [6] . Es decir, para ellos se cumplen las siguientes condiciones:
Además, el homomorfismo con respecto a las operaciones de suma y multiplicación es suficiente para que el sistema sea completamente homomórfico. [6]
El criptosistema creado por Craig Gentry basado en la criptografía de celosía describió la primera construcción posible para un sistema completamente homomórfico. El esquema de Gentry admitía las operaciones de suma y multiplicación sobre texto cifrado, lo que le permite construir anillos para implementar cualquier cálculo arbitrario.
La construcción comienza con un esquema de cifrado casi homomórfico , que solo es adecuado para calcular polinomios de grado pequeño sobre datos cifrados. (Esto está limitado por el hecho de que el texto cifrado contiene algo de ruido, que crece con las operaciones de suma y multiplicación en el texto cifrado, hasta que el ruido hace que el resultado sea ininteligible). Gantry mostró cómo modificar el esquema y hacerlo flexible . Es decir, con la ayuda del nuevo cifrado, pudo eliminar el ruido acumulado y realizar al menos una operación más en el texto cifrado.
Es decir, el esquema le permite evaluar su algoritmo de descifrado para al menos una operación más. Después de todo, demostró que cualquier esquema flexible se puede convertir en un esquema totalmente homomórfico mediante la autoincrustación recursiva.
Para un esquema Gentry "ruidoso", el procedimiento para modificar un esquema "flexible" efectivamente "actualiza" el texto cifrado al aplicarle un procedimiento de descifrado homomórfico, obteniendo así un nuevo texto que cifra los mismos datos que antes, pero con menos ruido. Al "actualizar" el texto cifrado periódicamente, cuando se alcanza un alto nivel de ruido, es posible realizar una cantidad arbitraria de operaciones sin interferencias. Gentry justificó la seguridad de su esquema con dos problemas: el problema de la complejidad de la criptografía del peor de los casos en redes ideales y el problema de la suma de subconjuntos.
El trabajo doctoral de Gentry [7] tiene una descripción más detallada.
A pesar de su rendimiento, los textos cifrados en el esquema Gentry siguen siendo compactos, ya que sus longitudes no dependen de la complejidad de la función que se calcula para los datos cifrados. Pero el esquema no es práctico debido al aumento dramático en el tamaño del texto cifrado y los costos computacionales según el nivel de protección. Damien Schechli y Ron Steinfeld introdujeron una serie de optimizaciones y mejoras, [8] y, posteriormente, Nigel Smart con Frederic Verkauteren , [9] [10] y Craig Gentry con Shai Halevi , [11] [ 12] presentó las primeras implementaciones de trabajo de un esquema de cifrado Gentry completamente homomórfico.
En 2010, Martin van Dijk , Craig Gentry , Shai Halevi y Weedon Vaikuntanahan presentaron un segundo sistema completamente homomórfico [13] . Usaba muchos de los principios del criptosistema de Gentry, pero no requería entramados perfectos . En cambio, demostraron que era posible reemplazar el componente homomórfico en redes ideales con un esquema homomórfico simple que usaría números enteros. Este esquema es conceptualmente más simple que el esquema Gentry, pero tiene parámetros similares en términos de homomorfismo y eficiencia.
El componente homomórfico en el trabajo de Dyck es similar al esquema de cifrado presentado por Leviel y Naccaha en 2008 [14] , y similar al presentado por Brahm Cohen en 1998 [15] . Pero el método de Cohen no es homomórfico con respecto a la operación de suma. El esquema de Leviela-Naccahi solo admite la operación de suma y se puede modificar para admitir una pequeña cantidad de operaciones de multiplicación. Jen-Sebastian Corona , Tankrid Lepointe , Avradip Mandala , David Nakkhi y Mehdi Tibuhi [16] [17] [18] [19] han presentado muchas mejoras y optimizaciones de circuitos en varios trabajos .
Varias técnicas nuevas han sido desarrolladas desde 2011-2012 por Zvik Brakerski , Craig Gentry , Widon Vaikuntanahan y otros. Estos desarrollos han llevado a una serie de criptosistemas completamente homomórficos más eficientes. Entre ellos:
La seguridad de la mayoría de los esquemas se basa en la dificultad de resolver el problema de aprendizaje de errores . Solo en el esquema LVT, la protección se implementa en una variante de la tarea computacional NTRU . Todos estos sistemas, a diferencia de los esquemas anteriores, tienen un aumento de ruido más lento durante los cálculos homomórficos. Como resultado de la optimización adicional realizada por Craig Gentry , Shai Haveli y Nigel Smart , se obtuvo un criptosistema con una complejidad asintótica casi óptima : [25] [26] [27] Estas optimizaciones se basan en la técnica Smart-Vercauteren, que le permite comprimir un conjunto de variables de texto en un texto cifrado y trabajar con estas variables en una secuencia . [10] Muchos avances de la segunda generación de sistemas totalmente homomórficos también se han utilizado en criptosistemas en números enteros. [18] [19]
Zvika Brakerski y Vidon Vaikuntanahan notaron que para varios esquemas, el criptosistema GSW muestra un ligero aumento en el nivel de ruido y, por lo tanto, una mayor eficiencia y mayor seguridad. [28] Jakob Alperin-Sheriff y Chris Peikert describieron más tarde una técnica eficiente de cifrado a flexible que utiliza este tipo de esquema. [29] Pero este tipo de transformación no es compatible con los métodos de compresión de texto cifrado y, por lo tanto, no se le pueden aplicar las optimizaciones de Gentry-Sahai-Waters [25] .
Hasta ahora, todos los criptosistemas de segunda generación siguen los fundamentos del diseño del esquema Gentry, es decir, utilizan un criptosistema casi homomórfico, con un gran nivel de crecimiento de ruido, y luego lo convierten en un criptosistema completamente homomórfico modificándolo en un esquema flexible.
La primera implementación de un cifrado completamente homomórfico fue el esquema Gentry-Halevi implementado sobre la base del esquema Gentry anterior. [12] Le tomó 30 minutos completar una operación simple con un bit. Tras la llegada de la segunda generación de criptosistemas, esta implementación se ha vuelto obsoleta.
Hay muchas implementaciones de sistemas casi homomórficos de segunda generación en la literatura. Implementado por Gentry, Haveli and Smart (GHS) [27] variación del criptosistema BGV, [20] mostró el resultado en 36 horas al calcular un esquema complejo (implementando encriptación AES ). Usando técnicas de compresión de texto cifrado, esta implementación podría recalcular el mismo esquema en 54 entradas diferentes en las mismas 36 horas, obteniendo así un resultado de 40 minutos por entrada. El cálculo del circuito AES fue elegido como guía para varios trabajos posteriores, [18] [30] [31] donde fue posible reducir significativamente el tiempo de cálculo a 4 horas, mientras se gastaban 7 segundos por entrada.
Dos implementaciones de la segunda generación de criptosistemas están disponibles para uso público:
Ambas bibliotecas son implementaciones de cifrado totalmente homomórfico. HElib muestra un resultado en 5-10 minutos para convertir texto cifrado comprimido de aproximadamente 1000 caracteres a flexible. [34] FHEW convierte el texto cifrado sin comprimir en texto cifrado flexible en aproximadamente 1/2 segundo por bit. [35] A finales de 2014, una implementación actualizada de HElib mostró un resultado de 4 minutos para calcular el esquema AES para 120 flujos de entrada, logrando así una velocidad específica de 2 segundos por flujo. [32]
El esquema de cifrado completamente homomórfico propuesto por Gentry se puede considerar usando el ejemplo de cálculos en . [36]
El proceso de cifrado de datos se puede representar de la siguiente manera:
1. Se elige un número impar arbitrario , que es un parámetro secreto. deja _
2. Se compila un número tal que , donde es un número arbitrario. Esto significa que .
3. En el proceso de encriptación, a cada uno se le asigna un número , donde se elige arbitrariamente. Así, . Es fácil ver que , y, por lo tanto, el atacante podrá determinar solo la paridad de la salida de cifrado.
Que se sepa el número encriptado y el secreto . Luego, el proceso de descifrado de datos debe contener los siguientes pasos:
1. Descifrado usando el parámetro secreto : , donde se llama ruido y .
2. Obtener el bit encriptado original :
Sean dos bits y se les asigna un par de números y . Que se tome el parámetro secreto y se cifren los datos: y .
La suma de estos números se calcula:
Por la suma de estos números, el mensaje descifrado será la suma de los bits originales .
Pero sin saberlo , no es posible descifrar los datos: .
La operación de multiplicación se comprueba de la misma manera:
Es necesario aplicar el procedimiento de descifrado a los resultados obtenidos, dando como resultado lo siguiente:
.
El uso de este esquema de cifrado completamente homomórfico para fines prácticos actualmente no es posible, ya que como resultado de los cálculos, el error acumulado alcanza rápidamente valores suficientemente grandes [36] . Incluso es posible que los datos no se puedan descifrar correctamente. Esto sucederá si el valor del error supera el valor de . En un intento por evitar este problema, Gantry desarrolló un mecanismo de autocorrección de texto cifrado (bootstrapping) que, debido a su impracticabilidad debido al crecimiento demasiado rápido del volumen de texto cifrado, no ha encontrado una amplia aplicación. Es posible resolver este problema, pero para lograr la tarea establecida, es necesario desarrollar algoritmos de cálculo más complejos o limitar la cantidad de operaciones en los datos. [36]
Una de las aplicaciones más importantes del cifrado totalmente homomórfico es realizar varias operaciones matemáticas en los datos almacenados en un almacenamiento remoto en la nube . El uso de un esquema de cifrado de este tipo permitirá crear un servicio en la nube seguro capaz de realizar varias operaciones en los datos del usuario sin saber qué tipo de datos son.
Deje, por ejemplo, que el usuario haya encriptado algunos de sus datos y los almacene en un almacenamiento remoto en la nube. Si el usuario tiene la intención de cambiar de alguna manera estos datos, puede confiar al servidor su clave secreta y, en consecuencia, acceder a toda su información secreta, o descargar los datos cifrados a su computadora, descifrarlos, hacer los cálculos necesarios y enviar de vuelta al servidor. Pero ni una forma ni la otra son óptimas. En el primer caso, es imposible excluir la probable fuga de datos y su acceso a terceros, en el segundo caso, el tiempo dedicado a realizar todas las operaciones necesarias puede ser demasiado alto. Además, es posible que el cliente simplemente no disponga de los recursos informáticos necesarios para realizar los cálculos que necesita. [6]
Asimismo, según la empresa internacional de investigación IDC , que estudia el mercado mundial de las tecnologías de la información y las telecomunicaciones , muchas empresas desconfían de las tecnologías en la nube, asociándoles, en primer lugar, grandes problemas en cuanto a la seguridad de los datos almacenados. Y la empresa de investigación independiente Portio Research publicó datos según los cuales el 68% de los responsables de varias empresas informáticas europeas no confían en dichos servicios. Entonces, por ejemplo, el jefe de G Data Security Labs , Ralph Bentzmuller, habló sobre los servicios en la nube de la siguiente manera: “Si no desea que sus datos se hagan públicos, no los almacene en el almacenamiento en la nube”. Por lo tanto, la cuestión de crear un almacenamiento seguro en la nube utilizando un esquema de cifrado de datos completamente homomórfico es actualmente bastante grave. [37] .
El cifrado totalmente homomórfico se usa en motores de búsqueda que requieren una "búsqueda privada", es decir, una búsqueda en la que el servidor no sabe nada sobre el contenido de la consulta de búsqueda y devuelve el resultado al usuario en forma cifrada. Además de las áreas ya cubiertas, se pueden aplicar esquemas de encriptación completamente homomórficos a los sistemas de votación electrónica , como cuando se usan firmas ciegas . [6]