Entwickler-Ecke
Algorithmen, Optimierung und Assembler - RSA geheimer Schlüssel
jelleton - Do 28.04.05 16:55
Titel: RSA geheimer Schlüssel
Folgendes Problem:
der geheime Schlüssel d wird aus dem öffentlichen Schlüssel c und dem Produkt zweier Primzahlen n wie folgt gebildet
d = (1 + k * Phi[n]) / c
wobei k eine beliebige Konstante ist, die aber vorraussetzt, dass die Division ohne Nachkommastellen vollzogen werden kann. Eine solche Konstante zu finden, ist irgendwie recht schwierig, da 1 + k * Phi[n] eine Zahl mit um die 60 Stellen ist. Gibt es eine schnellere und effizientere Methode als stupides ausprobieren?
MFG jelleton
Moderiert von
Christian S.: Topic aus Sonstiges verschoben am Do 28.04.2005 um 16:56
BenBE - Do 28.04.05 22:02
Da gilt d * e mod p == 1 kannst Du d = e^-1 mod p setzen und damit sehr effizient d berechnen.
jelleton - Do 28.04.05 22:20
BenBE hat folgendes geschrieben: |
Da gilt d * e mod p kannst Du d = e^-1 mod p setzen und damit sehr effizient d berechnen. |
(e^-1) mod p ?
da würde doch immer (e^-1) rauskommen, weil das dann eine sehr kleine Zahl ist, sozusagen "ein e-tel"..
Die Methode verstehe ich noch net so ganz.
BenBE - Do 28.04.05 22:28
jelleton hat folgendes geschrieben: |
(e^-1) mod p ?
da würde doch immer (e^-1) rauskommen, weil das dann eine sehr kleine Zahl ist, sozusagen "ein e-tel"..
Die Methode verstehe ich noch net so ganz. |
Stimmt so nicht ganz, weil Du mit Restklassen rechnest. Dort ist die Division so definiert, dass du immer Integerzahlen rausbekommst.
Für den Fall von oben wäre dies:
Delphi-Quelltext
1:
| d == e ^ (-1) mod p == e ^ (p - 2) mod p |
da
a ^ (p - 1) mod p == 1
Delphi-Quelltext
1:
| 1 == a ^ (p - 1) mod p == a * a ^ (p - 2) mod p |
Und zweiteres sieht stark nach der Ausgangsgleichung aus ^^ ;-)
Motzi - Do 28.04.05 22:29
Auf
http://www.manuel-poeter.de findest du meine Fachbereichsarbeit zum Thema Public-Key-Kryptographie speziell RSA. Schaus dir mal an, vielleicht hilft dir das weiter...
Entwickler-Ecke.de based on phpBB
Copyright 2002 - 2011 by Tino Teuber, Copyright 2011 - 2025 by Christian Stelzmann Alle Rechte vorbehalten.
Alle Beiträge stammen von dritten Personen und dürfen geltendes Recht nicht verletzen.
Entwickler-Ecke und die zugehörigen Webseiten distanzieren sich ausdrücklich von Fremdinhalten jeglicher Art!