![]() |
[LockBox3] Komischer Stream bei RSA Keys
Hallo,
ich mchte mit LockBox3 testweise ein Private und Public Key Paar generieren und in eine Datei speichern. Ich folge dabei dieser Anleitung: ![]() Installiert habe ich LockBox ber GetIt in der IDE. Mein Code ist wie folgt:
Delphi-Quellcode:
Ich kriege zwar das Dialog "Success" und es knallt nichts, also als ob alles gut gelaufen wre.
var
LStream : TFileStream; begin FSig := TSignatory.Create(nil); FCryptoLib := TCryptographicLibrary.Create(nil); FCodecRSA := TCodec.Create(nil); // setup codec FCodecRSA.CryptoLibrary := FCryptoLib; FCodecRSA.StreamCipherId := 'native.RSA'; FCodecRSA.ChainModeId:= 'native.CBC'; FCodecRSA.AsymetricKeySizeInBits := 1024; // setup sig FSig.Codec := FCodecRSA; // generate and save keys if FSig.GenerateKeys then begin LStream := TFileStream.Create('D:/public_key_test.txt', fmOpenReadWrite); try FSig.StoreKeysToStream(LStream, [partPublic, partPrivate]); finally LStream.Free; ShowMessage('Success'); end; end else ShowMessage('Failed'); end; In der Datei "D:\public_key_test.txt" finde ich aber folgenden Inhalt: Zitat:
Mache ich etwas falsch oder habe ich etwas vergessen? Freundliche Grsse Milos |
AW: [LockBox3] Komischer Stream bei RSA Keys
Versuch mal
Delphi-Quellcode:
LStream := TFileStream.Create('D:\public_key_test.txt', fmCreate);
|
AW: [LockBox3] Komischer Stream bei RSA Keys
Jo, wenn es weniger geschrieben wird, bleiben die alten Bytes ja vorhanden, wenn das mehr waren. (fmOpenReadWrite berbreibt ja nur)
oder nach dem Speichern noch ein
Delphi-Quellcode:
(ich glaub direkt eine Abschneiden-Funktion hat man in der RTL vergessen),
LStream.Size := LStream.Position;
bzw. vor dem speichern ein
Delphi-Quellcode:
LStream.Size := 0;
|
AW: [LockBox3] Komischer Stream bei RSA Keys
Hallo ihr beiden,
Vielen Dank fr eure Tipps. Ich habe beides versucht, leider auch ohne Erfolg. Bei himitsu's Vorschlag bin ich mir nicht 100% sicher ob ich das so gemacht habe wie es gedacht ist. Der Code sieht momentan so aus:
Delphi-Quellcode:
Der Output des Streams in eine neue Datei sieht leider immer noch hnlich aus:
var
LStream : TFileStream; begin FSig := TSignatory.Create(nil); FCryptoLib := TCryptographicLibrary.Create(nil); FCodecRSA := TCodec.Create(nil); // setup codec FCodecRSA.CryptoLibrary := FCryptoLib; FCodecRSA.StreamCipherId := 'native.RSA'; FCodecRSA.ChainModeId:= 'native.CBC'; FCodecRSA.AsymetricKeySizeInBits := 512; // setup sig FSig.Codec := FCodecRSA; // generate and save keys if FSig.GenerateKeys then begin LStream := TFileStream.Create('D:/rsa_keys.txt', fmCreate); try LStream.Position := 0; LStream.Size := 0; FSig.StoreKeysToStream(LStream, [partPublic, partPrivate]); LStream.Size := LStream.Position; finally LStream.Free; ShowMessage('Success'); end; end else ShowMessage('Failed'); end;
Code:
Folgende Dinge habe ich noch ausprobiert:
N
LockBox3 @ ™p „H*XVr\*9y›œv…€n`K 0)j7NCˆ@l @ a‡,‰"U;‘†“@ugO={~u\~Œ1#ҿhDzer=>= V! ›fm9m…tŠƒ*‡M/’c˜WDHIh ˜e*= X' wJŽwen4! h'90T|'&† }"i> c߬xdsI~š•jܨ, ˜0/dkEjMIaFs’M)t–},…˜N LockBox3 @ •†T*8y9]_=K߰21(b‚Et†=2e)T142:qh>&n’ @ Q J`X]& SdU‰IrKzIBw‰2#›˜0K;<Aj› |! –wNbrq‹Œ™mZž–& Q*h“а4ӾG?p’gXl><! q=pt ʰK!3`Ei%€p=†ka qžd{ߩFN‘OŽ(†kU‹&=4W.! ptz?ZW›Œ}’̳#€# - Manuelle Installation von LockBox3 ohne GetIt (bringt keine sprbare nderung) - Weitere Dinge mit LStream.Position und LStream.Size (auch kein Effekt) Mittlerweile denke ich eher dass dies ein Problem mit der Umgebung bzw. der Installation der Bibliothek ist. Knnte dies sein? Falls ja, was knnte ich tun um dies zu testen? Eine zweite Umgebung steht mir momentan leider nicht zur Verfgung. Knnte den Code jemand bei sich lokal testen und schauen ob auch solch ein "gibberish" rauskommt? Vielen Dank fr eure Untersttzung. |
AW: [LockBox3] Komischer Stream bei RSA Keys
ist zwar soppelt gemoppelt, aber jo, wrde passen.
Delphi-Quellcode:
setzt ebenfalls die Position in den noch vorhandenen Bereich (also auf 0)
LStream.Size := 0;
und wenn vorher schon gelscht wurde, dann ist nachher das
Delphi-Quellcode:
unntig, weil nach der (aktuellen) Position nichts mehr komen kann ... wurde ja schon zu beginn gelscht.
Size:=Position
im Grunde reicht entweder am Anfang auf 0 oder am Ende das Abschneiden, nach der aktuellen Position. Oder eben das ffnen und dabei sofort lschen (also fmCreate ist wie fmOpenReadWrite mit einem Size:=0) |
AW: [LockBox3] Komischer Stream bei RSA Keys
Zitat:
Leider besteht das Hauptproblem immer noch. Falls jemand noch ne Idee hat was ich tun knnte, wre ich sehr dankbar. :) Ich habe bemerkt, dass wenn ich versuche einen Key von einer Datei zu laden (der Key wurde mit einem externen Programm richtig generiert) bekomme ich beim Laden einen "Stream-Lesefehler". Also lesen und schreiben eines Keys in einen Stream scheint mit LockBox bei mir gar nicht zu funktionieren. Knnte dies ein Problem mit der Bibliothek LockBox3 sein? Edit: Hab das ganze nochmal auf einer frischen VM mit frischem Delphi versucht und kam zum exakt selbem Ergebnis, scheint also wahrscheinlich auch nicht an meiner Umgebung zu liegen. Komisch... :? Freundliche Grsse |
AW: [LockBox3] Komischer Stream bei RSA Keys
Zitat:
![]() ![]() ![]() Bis bald... Thomas |
AW: [LockBox3] Komischer Stream bei RSA Keys
Hi mytbo,
danke fr den Tipp. Ich wrde gerne bei LockBox bleiben um auch die anderen Features nutzen zu knnen. Sollte dies aber nicht funktionieren werde ich mir mORMot gerne mal genauer ansehen. :) Freundliche Grsse |
AW: [LockBox3] Komischer Stream bei RSA Keys
Wie wre es, wenn jemand den Debugger nimmt und schaut, was da passiert?
Delphi-Quellcode:
Und was das Lesen von fremden Keys betrifft ... hier ist es ein wohl eher binres und eventuell sogar "eigenes" propitres Format.
procedure TSignatory.StoreKeysToStream(
Store: TStream; Parts: TKeyStoragePartSet); begin if assigned( FCryptoKeys) then FCryptoKeys.StoreToStream( Store, Parts); if assigned( FSigningKeys) then FSigningKeys.StoreToStream( Store, Parts); end; procedure TAsymetricKeyPair.StoreToStream( Store: TStream; Parts: TKeyStoragePartSet); var hasPart: boolean; begin if partPublic in Parts then begin hasPart := assigned( FPublicPart) and (not FPublicPart.isEmpty); Store.WriteBuffer( hasPart, SizeOf( hasPart)); if hasPart then FPublicPart.SaveToStream( Store) end; if partPrivate in Parts then begin hasPart := assigned( FPrivatePart) and (not FPrivatePart.isEmpty); Store.WriteBuffer( hasPart, SizeOf( hasPart)); if hasPart then FPrivatePart.SaveToStream( Store) end end; Bei so Textdateien ala RSA PRIVATE KEY, wrde ich eher mal bei TOpenSSL_Signatory vorbeisehn. |
Alle Zeitangaben in WEZ +1. Es ist jetzt 13:33 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