Delphi-PRAXiS
Seite 1 von 2  1 2      

Delphi-PRAXiS (https://www.delphipraxis.net/forum.php)
-   Object-Pascal / Delphi-Language (https://www.delphipraxis.net/32-object-pascal-delphi-language/)
-   -   Delphi buchstaben-verschiebung optimieren... (https://www.delphipraxis.net/67598-buchstaben-verschiebung-optimieren.html)

heiopei 17. Apr 2006 13:56


buchstaben-verschiebung optimieren...
 
hallo,
ich hab neulich in ner alten pc-zeitschrift nen artikel gefunden, in dem gezeigt wurde, dass windows xp neben der "normalen" Dateibenutzungs-history diese zugriffe auch in der registry mitschreibt (bei mir rund 1400 einträge :!:).
dabei werden jedoch alle buchstaben(!!!) um 13 nach vorn verschoben (z.b. C => P) und die einträge somit "verschlüsselt" - entweder, dass nicht jeder depp die einträge entdeckt, oder zur "sicherheit", dass andere programme diese einträge nicht ohne weiteres lesen können (rechtliche absicherung :?: :roll: ).

=> man muss alle buchstaben wieder um 13 nach hinten verschieben, um die dateipfade lesbar zu machen

soweit so gut.

jetzt hab ich mir quick'n dirty ein programm geschrieben, dass diese einträge ausließt und sie schließlich entschlüsselt anzeigt. funktioniert bestens.

jetzt zur frage: man ist natürlich wieder perfektionist(ähm naja ein bisschen zumindest) und will alles verbessern. hier den verschliebungs-algo...:

Delphi-Quellcode:
const
  Shifter = 13;
...
function Shift_Letter(Letter: Char): Char;
const
  letters: array [1..52] of Char = (
  'A', 'B', 'C', 'D', 'E', 'F', 'G', 'H', 'I',
  'J', 'K', 'L', 'M', 'N', 'O', 'P', 'Q', 'R', 'S', 'T', 'U', 'V', 'W', 'X', 'Y', 'Z',
  'A', 'B', 'C', 'D', 'E', 'F', 'G', 'H', 'I',
  'J', 'K', 'L', 'M', 'N', 'O', 'P', 'Q', 'R', 'S', 'T', 'U', 'V', 'W', 'X', 'Y', 'Z');
var
  b: Byte;
begin
  result := letter;
  for b := 27 to 52 do
    if letter = letters[b] then
    begin
      result := letters[b - Shifter];
      Exit;
    end
    else if UpperCase(letter) = letters[b] then
    begin
      result := Chr(Ord(letters[b - Shifter]) + 32);
      Exit;
    end;
end;
...
d.h. ich definiere den verschiebungswert "shifter"(im bsp. 13) und vergleiche jeden buchstaben mit der tabelle "letters" (aber nur von index 27 bis 52). ist der buchstabe mit dem eintrag der tabelle gleich, gehe ich einfach in der tabelle um den wert "shifter" zurück, und gebe den buchstaben, der sich dort befindet aus. (ich berücksichtige dabei auch groß-/kleinschreibung...)

jetzt wollt ich nur wissen, inwiefern ich den algo optimieren kann (z.b. verzicht auf das array?...)

mfg,
heiopei

Basilikum 17. Apr 2006 14:11

Re: buchstaben-verschiebung optimieren...
 
ich würde spontan etwas in diese Richtung vorschlagen:
Delphi-Quellcode:
Function Shift_Letter(Letter: Char): Char;
Begin
  Case Letter Of
    'A'..'Z' : Result:=Chr( (((Ord(Letter) - Ord('A') + (26 - Shifter)) mod 26) + Ord('A') );
    'a'..'z' : Result:=Chr( (((Ord(Letter) - Ord('a') + (26 - Shifter)) mod 26) + Ord('a') );
    Else Result:=Letter;
  end;
end;
BTW: wo in der Registry stehen diese Infos ?

heiopei 17. Apr 2006 14:22

Re: buchstaben-verschiebung optimieren...
 
Liste der Anhänge anzeigen (Anzahl: 1)
hallo,
hab grad nachgeschaut, der artikel stammt aus der pc-professional von 8.03...

die schlüssel:
URL-liste (+ iexplore schließe ich aus den einträgen):
HKEY_CURRENT_USER\Software\Microsoft\Windows\Curre ntVersion\Explorer\UserAssist\
{5E6AB780-7743-11CF-A12B-00AA004AE837}\Count

dateiverwendungen (starten von programmen, öffnen von dateien... - komische kürzel am anfang ;-)):
HKEY_CURRENT_USER\Software\Microsoft\Windows\Curre ntVersion\Explorer\UserAssist\
{75048700-EF1F-11D0-9888-006097DEACF9}\Count

im anhang ist mal mein quellcode, keine zusätzlichen komponenten, einfach compilieren, liste auswählen und entschlüsseln => staunen :roll: :x :? :shock:

mfg,
heiopei

faux 17. Apr 2006 15:18

Re: buchstaben-verschiebung optimieren...
 
Zitat:

Zitat von Basilikum
ich würde spontan etwas in diese Richtung vorschlagen:

Wieso so kompliziert?
Delphi-Quellcode:
function Move13Chars(value char): char;
begin
  result := chr(ord(value) - 13);
end;
Habe ich was vergessen/überlesen?!

@heiopei:
Du hast bei deinem Anhang die Delphi-Referenz durchsuchenXOR_Letter-Prozedur verwendet. Die gibts bei meinem Delphi 7 nicht. :gruebel:
Ist die neu bei >=Delphi 2005 oder hast du die vergessen mitzugeben?

Grüße
Faux

SirThornberry 17. Apr 2006 15:23

Re: buchstaben-verschiebung optimieren...
 
und warum "ord"? schneller gehts das ganze einfach auf Byte zu casten

Hawkeye219 17. Apr 2006 15:26

Re: buchstaben-verschiebung optimieren...
 
@SirThornberry:

Nope, es wird der gleiche Assembler-Code erzeugt. That's Delphi!

Gruß Hawkeye

faux 17. Apr 2006 15:26

Re: buchstaben-verschiebung optimieren...
 
Zitat:

Zitat von SirThornberry
und warum "ord"? schneller gehts das ganze einfach auf Byte zu casten

Okay, wusste ich nicht. :oops:
Woher weiß man das, ohne den Source der Funktion ord zu kennen?

NACHTRAG:
Zitat:

Zitat von Hawkeye219
Nope, es wird der gleiche Assembler-Code erzeugt. That's Delphi!

Ääh? Was jetzt? :gruebel:

Sorry, hatte keinen roten Kasten. :?

Grüße
Faux

xaromz 17. Apr 2006 15:26

Re: buchstaben-verschiebung optimieren...
 
Hallo,
Zitat:

Zitat von SirThornberry
und warum "ord"? schneller gehts das ganze einfach auf Byte zu casten

"Ord" ist ja nur ein Überbleisel vergangener Tage. Das wird vom Compiler auch direkt gecasted.

Gruß
xaromz

Hawkeye219 17. Apr 2006 15:34

Re: buchstaben-verschiebung optimieren...
 
@faux:

Welchen Buchstaben liefert Deine Funktion, wenn Du ihr ein "A" übergibst?

faux 17. Apr 2006 15:35

Re: buchstaben-verschiebung optimieren...
 
Zitat:

Zitat von Hawkeye219
Welchen Buchstaben liefert Deine Funktion, wenn Du ihr ein "A" übergibst?

Keinen, aber eine Zahl. ;)
4

Aber sieh dir mal die oben genannten Schlüsseln an, ich kann da kein A finden... :tongue:

Grüße
Faux


Alle Zeitangaben in WEZ +1. Es ist jetzt 16:12 Uhr.
Seite 1 von 2  1 2      

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