![]() |
Ini-Verschlüsselung mit Class Helper
Vorab: Ich habe vor diesem Posting viel gesucht und nachgelesen. Und nein, ich habe keine passende Antwort gefunden.
Ich möchte ein gegebenes, größeres Projekt so erweitern, dass die geschriebenen Werte in eine Ini verschlüsselt abgelegt und gelesen werden können. TIniFile ableiten und entsprechende Zusatzfunktionen einbauen würde Unmengen an Änderungen am bestehenden Code mit sich bringen. Das ist nicht gewünscht. Das bedeutet, dass weiterhin ganz normal z.B. per
Delphi-Quellcode:
ein String ausgelesen werden können soll. Nur eben beim Lesen entschlüsselt.
var ini: TIniFile;
begin ini := TIniFile.Create(IniName); try myString := ini.ReadString('Section','Ident',''); finally ini.Free; end; Wie lässt sich das nun umsetzen? Meinde Idee war einen Klassenhelfer zu verwenden. Da ich bislang noch nicht damit gearbeitet habe, stolpere ich damit durch die Gegend. Ich dachte, das ginge jetzt so in der Art:
Delphi-Quellcode:
Überschrieben wird das damit schonmal, aber das Erben der normalen Funktionalität klappt nicht. Ginge das, könnte ich an Stelle des Kommentars die Funktion erweitern.
type
TIniFileHelper = class helper for TIniFile function ReadString(const Section, Ident, Default: string): string; end; implementation function TIniFileHelper.ReadString(const Section, Ident, Default: string): string; begin //hier später die Entschlüsselung inherited; end; Wie also statt des "inherited" Versuchs richtig? |
Re: Ini-Verschlüsselung mit Class Helper
Delphi-Quellcode:
type
TIniFileHelper = class(TIniFile) function ReadString(const Section, Ident, Default: string): string; override; end; : : : function TIniFileHelper.ReadString(const Section, Ident, Default: string): string; begin Result:=inherited ReadString(Section, Ident, Default); end; |
Re: Ini-Verschlüsselung mit Class Helper
Wow, das ging ja schnell!
Also das override wollte er nicht:
Code:
Nicht schlimm, wenn ich das weglasse, oder?
E2137 Methode 'ReadString' nicht in Basisklasse gefunden
Aber die Result-Zuweisung war scheinbar genau richtig. Klappt wie es soll. Danke! |
Re: Ini-Verschlüsselung mit Class Helper
Hallo zusammen,
mal vielleicht eine ganz dumme Frage, warum über eine Helper Klasse ? Ich kann das ganze doch auch so machen :
Delphi-Quellcode:
Warum sollte ich den Umständlichen Weg über eine extra Klasse gehen ? Welche Vorteile und Nachteile hat die Klasse gegenüber meiner Variante ?
ini := TINIFile(NSFile);
try Passwort := Entschluesseln(ReadString('Section', 'Ident', 'Default')); { ... Hier passiert noch etwas mit dem Passwort ...} finally ini.free; end; |
Re: Ini-Verschlüsselung mit Class Helper
Wenn man den ver/entschlüsselten Wert nur ein Mal auslesen möchte, dann geht Deine Variante natürlich auch.
Brauchst Du das an hundert Stellen, musst Du alle hundert Stellen anpassen. Mache ich das über die Helper-Klasse, brauche ich es nur ein Mal machen und mir in Zukunft keine Gedanken drüber zu machen. |
Re: Ini-Verschlüsselung mit Class Helper
Ein Class Helper ersetzt kein Veerbung. Man kann eine Klasse erweitern aber keine vorhandenen Funktionen verdecken
|
Re: Ini-Verschlüsselung mit Class Helper
Formel gesehen werden wohl tatsächlich keine Funktionen überschrieben. Aber praktisch gesehen schon.
Ich gebe zu, eine Vererbung oder Änderung des Originalquellcodes wären sauberer, aber auf diese Weise kann die Änderung "aufgesetzt" werden, ohne die Original-Funktionen oder den bereits gegebenen Quellcode anzurühren. Genau das war ja meine Frage und omata hat ja die Lösung bereits gepostet. Ich habe im Anschluss ein wenig weitergebastelt und bin mit der Lösung zufrieden. |
Re: Ini-Verschlüsselung mit Class Helper
Zitat:
|
Re: Ini-Verschlüsselung mit Class Helper
Er meint wenn er hundert Werte hat, also 100 mal ini.ReadString() aufruft, muss er alle 100 Aufrufe entsprechend erweitern. Nimmt er einen Class Helper oder leitet eine eigene Klasse ab, welche das Entschlüsseln in ReadString() implementiert ist es einfacher.
|
Re: Ini-Verschlüsselung mit Class Helper
Mir war aber so, als wenn man mit den ClassHelpern nur erweitern kann, ABER nichts überschreiben,
also müßte er vermutlich seine Funktion ReadString anders nennen und überall die "neue" Funktion direkt aufrufen :gruebel: Schließlich geht Overload NUR (egal wo), wenn sich die Funktions-Signatur (Parameter) unterscheidet. |
Re: Ini-Verschlüsselung mit Class Helper
Zitat:
|
Re: Ini-Verschlüsselung mit Class Helper
Wenn es mit dem Class Helper funktionieren würde, wäre das der einfachste Weg, da dessen Unit nur eingebunden werden muss und die neue Funktionaltität dann in der TIniFile zur Verfügung steht
|
Re: Ini-Verschlüsselung mit Class Helper
Mal hier zum zeigen wozu ein Class helper gut ist.
Ist kopiert deshalb als Zitat. Zitat:
|
Re: Ini-Verschlüsselung mit Class Helper
Hallo CodeX,
vielleicht hast du mit einer shadow class mehr Glück:
Delphi-Quellcode:
Am besten lagerst du Klassendefinition in eine eigene Unit aus. Du musst bei der Verwendung nur darauf achten, dass die neue Unit in der USES-Anweisung nach IniFiles auftaucht - falls du IniFiles überhaupt noch dort aufführen musst.
type
TIniFile = class (IniFiles.TIniFile) public function ReadString (const aSection, aKey, aDefault: string): string; end; function TIniFile.ReadString (const aSection, aKey, aDefault: string): string; begin Result := '<' + inherited ReadString(aSection, aKey, aDefault) + '>'; end; Gruß Hawkeye |
Re: Ini-Verschlüsselung mit Class Helper
Wie gesagt, Class Helper können die Klassen nicht direkt ändern, sondern nur etwas NEUES dazuschmuggeln,
aber hier gibt es einen Trick :angel: Die Unit muß als letzes (nach "IniFiles) dort eingebunden werden, wo die Ini-Klassen erstellt werden. Dann wird TIniFile.Create ersetzt und es werden überall die neuen Funktionen verwendet, da lokal (nachfolgend) immer die letzte Deklaration sichtbar ist und diese Funktionen praktischer Weise virtual sind. :)
Delphi-Quellcode:
Besser wäre es aber, wenn man DIESE TIniFile z.B. in TEncryptedIniFile umbenennt und dann überall TEncryptedIniFile.Create verwendet ... es geht aber auch wie oben, nur so wäre es "übersichtlicher".
unit EncyptedIniFiles;
interface uses IniFiles; type TIniFile = class(IniFiles.TIniFile) function ReadString(const Section, Ident, Default: string): string; override; procedure WriteString(const Section, Ident, Value: String); override; end; implementation function TIniFile.ReadString(const Section, Ident, Default: string): string; begin Result := Decypted(inherited ReadString(Section, Ident, Default)); end; procedure TIniFile.WriteString(const Section, Ident, Value: String); begin inherited WriteString(Section, Ident, Encypted(Value)); end; end. Info: Die "angedeutete" Verschlüsselung muß aber noch "eingebaut" werden. [edit] och menno :cry: |
Re: Ini-Verschlüsselung mit Class Helper
Ähm, was genau ist jetzt der Vorteil einer Shadow Class zu einem Class Helper?
Wie bereits geschrieben, wird auch bei einem Class Helper eine eigene gleichnamige Funktion bevorzugt behandelt, falls vorhanden. Das ist praktisch ein Überschreiben. Ich hab das ja wie gesagt schon eingebaut und es funktioniert. Die Info, dass das so geht, hatte ich ursprünglich von hier: ![]() |
Re: Ini-Verschlüsselung mit Class Helper
Zitat:
|
Re: Ini-Verschlüsselung mit Class Helper
Zitat:
|
Re: Ini-Verschlüsselung mit Class Helper
Mit Class-Helpern kann man eine Klasse nachträglich um neue Funktionen erweitern, ohne die Implementation der Klasse zu verändern.
Dießes bedeutet aber, daß man keine Funktionen/Prozeduren überschreiben und auch keine neuen Klassenvariablen einbauen kann, denn dieses würde die Klasse ändern, was ja nicht geht. Da du aber eine Funktion (hier ReadString) ersetzen willst, dann geht das also nicht. Du könntest höchstens die Funktion überladen, also eine gleichnamige neue Funktion einbinden, welche aber, wie beim Überladen üblich, eine andere Signatur haben muß. |
Re: Ini-Verschlüsselung mit Class Helper
@Frank: Es scheint ja komischerweise zu funktionieren, obwohl es in der Theorie nicht funktionieren dürfte
|
Re: Ini-Verschlüsselung mit Class Helper
Zitat:
|
Re: Ini-Verschlüsselung mit Class Helper
Warum soll das in der Theorie nicht gehen?
Selbst Borland schreibt in der Hilfe unter "Unterstützende Klassen": "[Beispiel ...] - Aufgerufen wird die Funktion MyFunc der unterstützenden Klasse, da diese Vorrang vor dem eigentlichen Klassentyp hat." |
Re: Ini-Verschlüsselung mit Class Helper
Delphi-Quellcode:
deswegen geht es nicht
uses IniFiles;
type TIniFileHelper = class helper for TIniFile procedure WriteString(const Section, Ident, Value: String); override; end; procedure TIniFileHelper .WriteString(const Section, Ident, Value: String); begin inherited WriteString(Section, Ident, Decrypt(Value)); end; Zitat:
|
Re: Ini-Verschlüsselung mit Class Helper
Ich bin Dir sehr dankbar, dass Du Dich mit dem Problem befasst. Aber wenn ich nun schon ein paar Mal gesagt habe, DASS es geht (warum auch immer), dann beruht es darauf, dass ich es ausprobiert habe.
Zu Deinem letzten Posting: Schau mal in Posting #3 in diesem Thread. |
Alle Zeitangaben in WEZ +1. Es ist jetzt 22:00 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 by Thomas Breitkreuz