AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Thema durchsuchen
Ansicht
Themen-Optionen

DCPCrypt in RAD Studio 10.3/10.4

Ein Thema von amigage · begonnen am 17. Nov 2020 · letzter Beitrag vom 25. Nov 2020
Antwort Antwort
Seite 1 von 2  1 2      
amigage

Registriert seit: 11. Nov 2005
Ort: Leipzig
272 Beiträge
 
Delphi 11 Alexandria
 
#1

DCPCrypt in RAD Studio 10.3/10.4

  Alt 17. Nov 2020, 17:52
Hallo,

ich verwendete bisher in RAD Studio 10.1 zum Verschlüsseln von Daten in Dateien die DCPCrypt Komponente V2.0 von David Barton.
Dabei nutzte ich die Funktionen EncryptCFB8Bit() zum Verschlüsseln von Informationen und Base64EncodeStr() um die Daten im Base64-Format zu schreiben.
Zum Auslesen nutzte ich Base64DecodeStr() und DecryptCFB8Bit() .
Kompiliert wurde eine 32 und eine 64 Bit Version meines Programms.

Nun wollte ich dieses Projekt auf 10.4 bringen und erhalte beim Kompilieren einen Debugger-Fehler.
Daraufhin habe ich die DCPCrypt Komponente V2.1 installiert, die bereits schon seit Jahren auf Unicode umgestellt wurde.
Der Debugger steigt auch nicht mehr aus.

Aber hier habe ich das Problem, dass ich die "alten" Dateien nicht mehr lesen kann, da Sie falsch entschüsselt werden.
Ich vermute, weil jetzt die bedingte Kompilierung {$IFDEF UNICODE} automatisch aktiviert ist und das Programm in die Dekodierung des Unicodeformats springt.


Delphi-Quellcode:
function Base64DecodeStr(const Value: AnsiString): AnsiString;
begin
{$IFDEF NEXTGEN}
  Result.SetLength((AnsiLength(Value) div 4) * 3);
  Result.SetLength(Base64Decode(@Value.GetBuffer[0],@Result.GetBuffer[0],AnsiLength(Value)));
{$ELSE}
  SetLength(Result,(Length(Value) div 4) * 3);
  SetLength(Result,Base64Decode(@Value[1],@Result[1],Length(Value)));
{$ENDIF}
end;

{$IFDEF UNICODE}
function Base64DecodeStr(const Value: UnicodeString): UnicodeString;
var
  temp: AnsiString;
begin
  temp:= AnsiString(Value);
{$IFDEF NEXTGEN}
  SetLength(Result,(AnsiLength(temp) div 4) * 3);
  SetLength(Result,Base64Decode(@temp.GetBuffer[0],@Result[1],AnsiLength(temp)) div SizeOf(Result[1]));
{$ELSE}
  SetLength(Result,(Length(temp) div 4) * 3);
  SetLength(Result,Base64Decode(@temp[1],@Result[1],Length(temp)) div SizeOf(Result[1]));
{$ENDIF}
end;
{$ENDIF}
Kann man diese UNICODE Standardeinstellung temporär umgehen, so dass ich die alten Daten noch entsprechend ausgelesen bekomme?

Vielen Dank für eure Bemühungen und Tipps.
  Mit Zitat antworten Zitat
hoika

Registriert seit: 5. Jul 2006
Ort: Magdeburg
8.275 Beiträge
 
Delphi 10.4 Sydney
 
#2

AW: DCPCrypt in RAD Studio 10.3/10.4

  Alt 17. Nov 2020, 18:28
Hallo,
ich sehe ja den Interface-Teil nicht, aber

function Base64DecodeStr(const Value: AnsiString): AnsiString;
function Base64DecodeStr(const Value: UnicodeString): UnicodeString;

Kann es sein, dass die Methode überladen ist?
Dann solltest Du als Parameter einen AnsiString und nicht einen normalen String übergeben.
Heiko
  Mit Zitat antworten Zitat
amigage

Registriert seit: 11. Nov 2005
Ort: Leipzig
272 Beiträge
 
Delphi 11 Alexandria
 
#3

AW: DCPCrypt in RAD Studio 10.3/10.4

  Alt 17. Nov 2020, 18:40
Danke für die schnelle Antwort.
Hier ist der interface Teil.
Delphi-Quellcode:
uses
  {$ifdef NEXTGEN_FIXES}
    ORawByteString,
  {$endif}
     Sysutils;

function Base64EncodeStr(const Value: AnsiString): AnsiString; overload;
  { Encode a string into Base64 format }
function Base64DecodeStr(const Value: AnsiString): AnsiString; overload;
  { Decode a Base64 format string }
{$IFDEF UNICODE}
function Base64EncodeStr(const Value: UnicodeString): UnicodeString; overload;
  { Encode a Unicode string into Base64 format }
function Base64DecodeStr(const Value: UnicodeString): UnicodeString; overload;
  { Decode a Base64 format Unicode string }
{$ENDIF}
function Base64Encode(pInput: pointer; pOutput: pointer; Size: longint): longint;
  { Encode a lump of raw data (output is (4/3) times bigger than input) }
function Base64Decode(pInput: pointer; pOutput: pointer; Size: longint): longint;
  { Decode a lump of raw data }
  Mit Zitat antworten Zitat
hoika

Registriert seit: 5. Jul 2006
Ort: Magdeburg
8.275 Beiträge
 
Delphi 10.4 Sydney
 
#4

AW: DCPCrypt in RAD Studio 10.3/10.4

  Alt 17. Nov 2020, 19:03
Hallo,
dann siehe mein Post davor. (AnsiString benutzen)
Heiko
  Mit Zitat antworten Zitat
Benutzerbild von Codehunter
Codehunter

Registriert seit: 3. Jun 2003
Ort: Thüringen
2.272 Beiträge
 
Delphi 10.4 Sydney
 
#5

AW: DCPCrypt in RAD Studio 10.3/10.4

  Alt 18. Nov 2020, 09:29
Und eine Form von Versionskennung in deinem Dateiformat kann auch nicht schaden. Damit du in Zukunft unterscheiden kannst ob du es mit neuerem Unicode zu tun hast oder nicht.
Ich mache grundsätzlich keine Screenshots. Schießen auf Bildschirme gibt nämlich hässliche Pixelfehler und schadet der Gesundheit vom Kollegen gegenüber. I und E zu vertauschen hätte den selben negativen Effekt, würde aber eher dem Betriebsklima schaden
  Mit Zitat antworten Zitat
amigage

Registriert seit: 11. Nov 2005
Ort: Leipzig
272 Beiträge
 
Delphi 11 Alexandria
 
#6

AW: DCPCrypt in RAD Studio 10.3/10.4

  Alt 18. Nov 2020, 13:09
Leider hilft auch der Typecast nicht. Das Programm ruft dann zwar die korrekte Base64 Dekodierung auf. Aber die zurückgegebene Zeichenkette ist nur halb korrekt.

Als Beispiel nehmen wir die Zeichenkette "Ein kleines Beispiel".
Die vor Jahren erstellte base64 Zeichenfolge lautet: wkzVX952oBvST6gg4kFA18IaSGsEjjc=
Will ich diese jetzt wieder mit dem richtigen Passwort dekodieren, erhalte ich z.B. nur: BÝ9ý–éžÏÕnes Beispiel"

Woran könnte es noch liegen?

Was ich vergaß, zu erwähnen: bei einer 32Bit Kompilierung unter 10.3/10.4 funktionierte die alte Version 2.0 noch tadellos. Nur bei einer 64 Bit Kompilierung stieg der Debugger mit einer Fehlermeldung aus. Was könnte der Grund dafür sein?

Geändert von amigage (18. Nov 2020 um 13:15 Uhr)
  Mit Zitat antworten Zitat
Achim Kalwa

Registriert seit: 2. Apr 2005
Ort: Lienen
110 Beiträge
 
Delphi 12 Athens
 
#7

AW: DCPCrypt in RAD Studio 10.3/10.4

  Alt 19. Nov 2020, 12:44
Wenn ich Deinen Base64-String mit einem Online-Decoder decodiere, kommt eine Folge von Bytes heraus, die ich hier mal als Hex-Zahlen darstelle:

c2 4c d5 5f de 76 a0 1b d2 4f a8 20 e2 41 40 d7 c2 1a 48 6b 04 8e 37

Das ist also kein Klartext mit ASCII- oder ANSI-Zeichen, sondern eine Byte-Folge.
Damit es nicht zu einer ungewollten Unicode-Konvertierung der Nicht-ASCII-Zeichen kommt, musst Du einen Datentyp verwenden, der Bytes speichert und nicht (Ansi/Wide-)Char.

Versuche mal, das Ergebnis von Base64DecodeStr() in einer Variable vom Typ RawByteString zu speichern. Diesen "String" übergibst Du dann an DCPCrypt zum entschlüsseln. Falls Das von Dir gewählte Password Umlaute oder andere Nicht-ASCII-Zeichen enthält, bekommst Du aber ein weiteres Problem...

HTH
Achim
Achim
  Mit Zitat antworten Zitat
amigage

Registriert seit: 11. Nov 2005
Ort: Leipzig
272 Beiträge
 
Delphi 11 Alexandria
 
#8

AW: DCPCrypt in RAD Studio 10.3/10.4

  Alt 20. Nov 2020, 12:07
Vielen Dank für die Vorschläge.

Ich habe weitere Tests durchgeführt und kann sagen, dass es nicht an der Base64DecodeStr() Funktion liegt. Diese gibt bei beiden Versionen (2.0 und 2.1) den gleichen RawByteString zurück.
Es liegt also an den DecryptCFB8Bit() Funktionen der Verschlüsselungsarten, respektive EncryptECB() .

Denn hier wurden folgende Änderungen vorgenommen:

In der DCPCrypt2.pas wurden allgemein folgende Datentypen eingeführt:

Delphi-Quellcode:
type

{$IF CompilerVersion >= 23}
{$DEFINE DELPHIXE2_UP}
{$IFEND}
{$IFNDEF DELPHIXE2_UP}
   NativeInt = {$IFDEF WIN64} int64 {$ELSE} Longint {$ENDIF};
{$ENDIF}
   PointerToInt = {$IFDEF DELPHIXE2_UP} Pbyte {$ELSE} NativeInt {$ENDIF};

In den verschiedenen Verschlüsselungsarten wurden folgende Änderungen vorgenommen, z.B. TwoFish.pas:

V2.0
Delphi-Quellcode:
  x[1]:= PDWord(longword(@InData)+4)^ xor SubKeys[INPUTWHITEN+1];
  x[2]:= PDWord(longword(@InData)+8)^ xor SubKeys[INPUTWHITEN+2];
  x[3]:= PDWord(longword(@InData)+12)^ xor SubKeys[INPUTWHITEN+3];
V2.1
Delphi-Quellcode:
  x[1]:= PDWord(PointerToInt(@InData)+4)^ xor SubKeys[INPUTWHITEN+1];
  x[2]:= PDWord(PointerToInt(@InData)+8)^ xor SubKeys[INPUTWHITEN+2];
  x[3]:= PDWord(PointerToInt(@InData)+12)^ xor SubKeys[INPUTWHITEN+3];
Longword (Alias für Cardinal - ist 32 Bit auf allen 64-Bit- und 32-Bit-Plattformen.) wurde durch PointerToInt (PByte repräsentiert einen Zeiger auf Byte) ersetzt.

Es sieht wohl so aus, dass ich wohl die alten Daten nicht mehr auslesen kann. Hier scheint es wohl bei einer 64Bit Kompilierung keine Rückwärtskompatibilität zu geben, was natürlich in so einem Fall fatal ist.
  Mit Zitat antworten Zitat
TurboMagic

Registriert seit: 28. Feb 2016
Ort: Nordost Baden-Württemberg
2.942 Beiträge
 
Delphi 12 Athens
 
#9

AW: DCPCrypt in RAD Studio 10.3/10.4

  Alt 20. Nov 2020, 20:56
Schon Mal versucht den Verschlüsselungsalgorithmus mit DEC (Delphi Encryption Compendium) umzusetzen?

Davon den aktuellen Development Branche nutzen.
Sollte den Verschlüsselungsalgorithmus, Base64 und den angegebenen Blockverkettungsalgorithmus unterstützen.
  Mit Zitat antworten Zitat
amigage

Registriert seit: 11. Nov 2005
Ort: Leipzig
272 Beiträge
 
Delphi 11 Alexandria
 
#10

AW: DCPCrypt in RAD Studio 10.3/10.4

  Alt 22. Nov 2020, 12:14
Vielen Dank für den Tipp, ich werde es mir einmal anschauen.
  Mit Zitat antworten Zitat
Antwort Antwort
Seite 1 von 2  1 2      


Forumregeln

Es ist dir nicht erlaubt, neue Themen zu verfassen.
Es ist dir nicht erlaubt, auf Beiträge zu antworten.
Es ist dir nicht erlaubt, Anhänge hochzuladen.
Es ist dir nicht erlaubt, deine Beiträge zu bearbeiten.

BB-Code ist an.
Smileys sind an.
[IMG] Code ist an.
HTML-Code ist aus.
Trackbacks are an
Pingbacks are an
Refbacks are aus

Gehe zu:

Impressum · AGB · Datenschutz · Nach oben
Alle Zeitangaben in WEZ +1. Es ist jetzt 22:28 Uhr.
Powered by vBulletin® Copyright ©2000 - 2024, Jelsoft Enterprises Ltd.
LinkBacks Enabled by vBSEO © 2011, Crawlability, Inc.
Delphi-PRAXiS (c) 2002 - 2023 by Daniel R. Wolf, 2024 by Thomas Breitkreuz