Partage de clé secrète de ShamirLe partage de clé secrète de Shamir (Shamir's Secret Sharing) est un algorithme de cryptographie créé par Adi Shamir[1]. C'est une forme de secret réparti, où un secret est divisé en parties, donnant à chaque participant sa propre clé partagée, où certaines des parties ou l'ensemble d'entre elles sont nécessaires afin de reconstruire une phrase de passe qui donne accès au secret. Parfois, il n'y a pas forcément besoin de tous les participants pour reconstituer le minimum nécessaire qui forme la phrase de passe d'accès au secret, c'est pourquoi est utilisé parfois le schéma seuil où un nombre k des parties est suffisant pour reconstruire le secret d'origine. Explication avancéeLe partage de clés secrètes de Shamir est utilisé pour sécuriser l'accès à un secret (un fichier, un texte...) de manière distribuée, le plus souvent pour sécuriser d'autres clés de chiffrement. Le secret est divisé en plusieurs morceaux, appelées parties. Ces morceaux, en éclats de verre, sont utilisés pour reconstituer le secret original : la phrase de passe. Ce qui s'apparente à une technique de hachage d'une phrase de passe, qui donne accès au secret, en plusieurs morceaux de clés. Pour déverrouiller l'accès au secret via le partage de clès secrètes de Shamir, vous avez besoin d'un nombre minimum de parties réunies. C'est ce qu'on appelle le seuil, qui est utilisé pour indiquer le nombre minimum de parties nécessaires pour réconstituer la phrase de passe et déverrouiller l'accès au secret. Prenons un exemple :
C'est là qu'intervient le partage de clé secrète de Shamir. Il peut être utilisé pour chiffrer le mot de passe du coffre-fort et générer un certain nombre de parties, une configuration dans laquelle un certain nombre de parties peut être attribué à chaque dirigeant de la société XYZ. Ce n'est que s'ils mettent leurs parties en commun qu'ils peuvent reconstituer la phrase de passe secrète pour déverrouiller le coffre-fort. Le seuil peut être fixé de façon appropriée en fonction du nombre de personnes impliquées, de sorte que le coffre-fort soit toujours accessible par les personnes autorisées. Si une partie ou deux tombaient entre de mauvaises mains, cela ne permettrait pas de déverrouiller par mot de passe à moins que les autres dirigeants ne coopèrent avec leurs parties distribuées auparavant. Définition mathématiqueFormellement, notre objectif est de diviser certaines données (par exemple, la combinaison du coffre) en pièces de telle sorte que:
Ce régime est appelé schéma seuil . Si alors tous les participants sont nécessaires pour reconstituer le secret. Système de partage de secret de ShamirL'idée essentielle d'Adi Shamir est que 2 points sont suffisants pour définir une ligne, 3 points suffisent à définir une parabole, 4 points pour définir une courbe cubique, etc. Autrement dit, il faut points pour définir un polynôme de degré . Supposons que nous voulons utiliser un schéma de seuil pour partager notre secret , que l'on suppose, sans perte de généralité, être un élément dans un corps fini . Choisir au hasard coefficients dans , et poser . Construire le polynôme . Soient n'importe quels points calculés à partir de lui, par exemple qui donnent . Chaque participant se voit attribuer un point (un couple d'antécédent et de l'image correspondante par la fonction polynomiale). Étant donné un sous-ensemble de de ces couples, nous pouvons trouver les coefficients du polynôme à l'aide de l'interpolation polynomiale, le secret étant le terme constant . UtilisationExempleL'exemple suivant illustre l'idée de base. Notez, cependant, que les calculs sont effectués sur des entiers plutôt que dans un corps fini. Par conséquent, l'exemple ci-dessous ne fournit pas le secret parfait, et n'est pas un véritable exemple du régime de Shamir. PréparationSupposons que notre secret est 1234 . Nous tenons à partager le secret en 6 parties , où une réunion quelconque de 3 parties suffit pour reconstruire le secret. Au hasard, on obtient 2 numéros: 166, 94.
Le polynôme pour produire les clés est donc:
Nous avons construit 6 points à l'aide du polynôme :
Nous donnons à chaque participant un point différent (à la fois et ). ReconstructionAfin de reconstituer le secret, 3 points seront suffisants. Par exemple : . Le polynôme de Lagrange associé s'écrit : où les ℓj sont les polynômes de base de Lagrange :
Par conséquent :
Rappelons que le secret est le premier coefficient, ce qui signifie que , et on a fini. PropriétésCertaines des propriétés utiles du schéma seuil de Shamir sont les suivantes :
Porte dérobéeIl est possible de créer très facilement une porte dérobée dans l'implémentation d'un logiciel du partage de clé secrète de Shamir. Vous pouvez présenter un code source qui ne présente aucun souci puis compiler avec un "Œuf de Pâques" (Easter egg) qui contiendra une porte dérobée. En l'absence des coefficients du polynôme, les participants ne peuvent vérifier si l'autorité les trompe ou non. Tout a l'"air aléatoire". Les deux exemples suivants veulent attirer l'attention sur la possibilité qu'un seul participant bien choisi peut obtenir le secret dans le cas (3,5) ou que deux participants bien choisis peuvent également s'associer pour obtenir le secret dans le cas du seuil (3,5). On peut bien sûr généraliser au cas (k,n). Il ne s'agit pas d'une attaque du schéma, seulement de la possibilité, au niveau logiciel, que l'autorité puisse tromper la plupart des participants. Il est possible qu'une configuration logicielle, par défaut, permette cette possibilité. ExemplesUtilisation de Pari/GP - version 2.5.0 : sont adoptées ici les notations du livre « Cryptographie : Théorie et Pratique », Douglas Stinson, 1996, Chapitre 11 « Systèmes de partage de secret »[réf. nécessaire] Schéma de seuil (3,5) : un participant connait le secretLe choix du nombre premier , du secret , de et de est arbitraire : est aléatoire (), le choix de l'autre coefficient secret ici n'est pas aléatoire du tout :
Calcul classique des clés :
Vérification avec la coalition : 1 3 5
/* Mais x_1 détenait déjà l'information (sans le savoir ?) */ Résultats : %58 = 8017 %59 = Mod(4131, 8017) %60 = [Mod(1, 8017), Mod(2, 8017), Mod(30, 8017), Mod(4, 8017), Mod(5, 8017)] %61 = Mod(7907, 8017) %62 = [Mod(7907, 8017), Mod(110, 8017)] %63 = [Mod(4131, 8017), Mod(4351, 8017), Mod(3627, 8017), Mod(5451, 8017), Mod(6331, 8017)] %64 = [Mod(2904, 8017), Mod(5916, 8017), Mod(7215, 8017)] %65 = Mod(4131, 8017) %66 = [Mod(2865, 8017), Mod(1947, 8017), Mod(3206, 8017)] %67 = Mod(4131, 8017) On a une information y[1]: %68 = Mod(4131, 8017) / schéma de seuil (3,5) : deux participants ensemble connaissent le secretLa somme de la clé du 1er participant et de la clé du 2e participant fournit le secret /* le choix du nombre premier P, du secret K, de x et de AA est arbitraire */ P=prime(1010) K=Mod(4131,P) AA=Mod(124,P)
a=Mod([AA,(-K-AA*(x[1]+x[2]))/(x[1]*x[1]+x[2]*x[2])],P)
y=[K+a[1]*x[1]+a[2]*x[1]*x[1],K+a[1]*x[2]+a[2]*x[2]*x[2],K+a[1]*x[3]+a[2]*x[3]*x[3],K+a[1]*x[4]+a[2]*x[4]*x[4],K+a[1]*x[5]+a[2]*x[5]*x[5]] /* Vérification avec la coalition: 1 3 5 */ b=[x[3]*x[5]/((x[3]-x[1])*(x[5]-x[1])),x[1]*x[5]/((x[1]-x[3])*(x[5]-x[3])),x[1]*x[3]/((x[1]-x[5])*(x[3]-x[5]))] secret=b[1]*y[1]+b[2]*y[3]+b[3]*y[5] print("On a une information y[1]+y[2]:") y[1]+y[2] Résultats : %69 = 8017 %70 = Mod(4131, 8017) %71 = Mod(124, 8017) %72 = [Mod(124, 8017), Mod(5513, 8017)] %73 = [Mod(1751, 8017), Mod(2380, 8017), Mod(7028, 8017), Mod(4648, 8017), Mod(6287, 8017)] %74 = [Mod(2904, 8017), Mod(5916, 8017), Mod(7215, 8017)] %75 = Mod(4131, 8017) On a une information y[1]+y[2] : %76 = Mod(4131, 8017) Liens externes
Notes et références
|