![]() |
Dateiverschlüsselung mit DEC (5.2)
Liste der Anhänge anzeigen (Anzahl: 1)
Hallo,
in einer Client-Server-Umgebung möchte ich, dass der Server dem Client eine Datei zur Verfügung stellt. Diese soll verschlüsselt werden. Dem Client werden dann nur der Name/Pfad der verschlüsselten Datei auf einem Fileserver und das Passwort übermittelt. Nun möchte ich aus Sicherheitsgründen auf dem Client die Datei nicht zwischenspeichern, sondern als TMemoryStream weiter verarbeiten. Ich verwende dazu die DEC und einen stark abgewandelten Code aus der Demo ( ![]() Das Verschlüsseln klappt. Wenn ich mit dem Server wieder entschlüssele, gibt es kein Problem. Wenn ich aber mit dem Client das Entschlüsseln versuche, bekomme ich eine Exception mit der Fehlermeldung "Class 89504E47 is not registered". Es hat auch nichts gebracht
Delphi-Quellcode:
einzufügen.
Initialization
IdentityBase:=$89504E47; Ich gehe der Kommentierung nach davon aus, dass es daran liegt, dass nur ein und dasselbe Programm ver- bzw. entschlüsseln darf. Ich begreife nicht, wie ich den Code abändern kann/muss, damit es klappt. Zudem möchte ich (auch) gern sicherstellen, dass nur der passende Client dechiffriert. Ich habe die von mir verwendete Unit mal beigefügt. Diese wird sowohl vom Server als auch vom Client verwendet. Es betrifft dort die Funktionen EncryptFile() und DecryptFile(). Danke für die Hinweise, Alex |
AW: Dateiverschlüsselung mit DEC (5.2)
registrierst du die algorithmen? z.b. so:
Delphi-Quellcode:
das mußt du auch auf dem client machen, dann sollte das klappen.
procedure RegisterClasses;
begin TFormat_Copy.register; TFormat_HEX.register; TFormat_MIME64.register; TFormat_MIME32.register; THash_SHA512.register; THash_Whirlpool.register; TCipher_Twofish.register; TCipher_Rijndael.register; SetDefaultCipherClass(TCipher_Rijndael); SetDefaultHashClass(THash_SHA512); IdentityBase := $84282255; end; |
AW: Dateiverschlüsselung mit DEC (5.2)
Danke für die schnelle Antwort!
Zitat:
Delphi-Quellcode:
Oder sind das verschiedene Dinge?
Var
AKDFIndex : LongWord = 1; ACipherMode : TCipherMode = cmCBCx; AHashClass : TDECHashClass = THash_Whirlpool; ACipherClass : TDECCipherClass = TCipher_Rijndael; ATextFormat : TDECFormatClass = TFormat_Mime64; Ich werde Deinen Vorschlag mal ausprobieren. <- klappt leider nicht [edit]Ich habe auch den - übersehenen - Teil aus dem ![]()
Delphi-Quellcode:
Das klappt leider auch nicht[/edit]
SetDefaultCipherClass(TCipher_Rijndael);
SetDefaultHashClass(THash_SHA1); IdentityBase := $84485225; RegisterDECClasses([TCipher_Rijndael, THash_SHA1]); Gruß, Alex |
AW: Dateiverschlüsselung mit DEC (5.2)
Zitat:
das wichtige is das registrieren.
Delphi-Quellcode:
das kannst du im oncreate event machen, oder sonst wo bevor du mit dem verschlüsseln anfängst. das mußt du im server sowie auch im client machen.
THash_Whirlpool.register;
|
AW: Dateiverschlüsselung mit DEC (5.2)
Zitat:
Zitat:
|
AW: Dateiverschlüsselung mit DEC (5.2)
kannst du mit dem server entschlüsseln?
|
AW: Dateiverschlüsselung mit DEC (5.2)
Zitat:
Delphi-Quellcode:
Ich habe dann im Stamm von C: die Datei, die sich problemlos öffnen lässt und mit dem Original übereinstimmt. Ich verwende einunddieselben Functionen im Client und im Server und bin entsprechend ratlos...
S:=CreateKey;
S2:=NameCryptFile(EdPollDir.Text, 'enc'); Try EncryptFile(Strings[0] + '_sign.png',// zugehörige Unterschrift S2, S); DecryptFile(S2, 'C:\Test_Server.png', S); ... Except // Fehlerbehandlung, falls Verschlüsseln nicht klappt End; Gruß, Alex |
AW: Dateiverschlüsselung mit DEC (5.2)
sehr merkwürdig sollte eigentlich klappen. fällt mir auch nix zu ein. :(
|
AW: Dateiverschlüsselung mit DEC (5.2)
Zitat:
Ich lasse mir nun das Passwort, die Datei etc. anzeigen (ShowMessage()), die alle übereinstimmen. Auch habe ich mit separatem Code das Verschlüsseln und Entschlüsseln mit separaten Programmen* trainiert :lol:. Das klappt und noch besser wird es, wenn der Server verschlüsselt und ich mit meinem separaten Entschlüsselungs-Programm (Siehe *) die Datei erfolgreich und ohne jede Fehlermeldung entschlüsseln kann. Das kann ich nun überhaupt nicht mehr nachvollziehen :gruebel: Daran dass es ein anderes Programm ist, kann es also nicht liegen. Bevor ich es vergesse: * in meinen separaten Testprogrammen stehen hier übrigens nur 3 Zeilen und auch das Entfernen der Kommentare bringt nichts:
Delphi-Quellcode:
Der Fehler MUSS also in meinem Client-Programm liegen. Da ich meine Unit Encryption in allen Programmen unverändert benutze, KANN er hier nicht liegen. Kann mir mal bitte jemand einen Hinweis geben, wie/wo ich anfangen kann zu suchen? Ich möchte ungern meinen gesamten Client hier reinstellen. Das sind mehrere tausend Programmzeilen. Das kann ich keinem zumuten.
Initialization
Randomize; // THash_SHA1.Register; // es läuft auch ohne ?!? // TCipher_Rijndael.Register; // es läuft auch ohne ?!? SetDefaultHashClass(THash_SHA1); SetDefaultCipherClass(TCipher_Rijndael); [scherz] Von mir aus auch damit: :glaskugel:[/scherz] der völlig ratlose Alex |
AW: Dateiverschlüsselung mit DEC (5.2)
:duck: Ganz dummer Fehler:
Delphi-Quellcode:
Ist an sich selbsterklärend. Wenn man aber im Träumen dem Decrypter statt dem .CryptFile die unverschlüsselte Datei (.FileName) übergibt, braucht man sich über Fehler nicht zu wundern.
Type
TSignJob = Packed Record FileName : String; Password : String; CryptFile : String; End; Jetzt klappt es! Wünschenswert wäre es nur, wenn die Fehlermeldungen nicht so kryptisch, sondern besser zu verstehen wären. Wäre dieser Wunsch etwas für ![]() Gruß, Alex |
Alle Zeitangaben in WEZ +1. Es ist jetzt 11:12 Uhr. |
Powered by vBulletin® Copyright ©2000 - 2025, Jelsoft Enterprises Ltd.
LinkBacks Enabled by vBSEO © 2011, Crawlability, Inc.
Delphi-PRAXiS (c) 2002 - 2023 by Daniel R. Wolf, 2024-2025 by Thomas Breitkreuz