![]() |
String mit ReadMemoryProcess auslesen
Hallo, ich habe diverse Funktionen um Integer Werte aus dem Speicher fremder Programme auszulesen oder Funktionen mit z.b. Nop zu überpatchen. Leider finde ich aber keinerlei möglichkeit einen Textwert aus einer Adresse auszulesen. In der Adresse stehen die Namen aller Clients drin, die ich gern extern auswerten Würde. Wie stellt man das am besten an?
|
Re: String mit ReadMemoryProcess auslesen
Die Frage ist, was für ein String ist das. Pascal String? 0-terminiert? Ein Char Array fixer Länge? Je nachdem gäbe es unterschiedliche Möglichkeiten. Wenn der String keine fixe Länge hat (= Char Array) ist das Hauptproblem die Länge des Strings zu ermitteln. Bei Pascal Strings ist das noch relativ simpel zu ermitteln, da der erste Wert die Länge angibt. Bei Null-Terminierung dagegen muss wahrscheinlich zeichenweise gelesen werden bis man am 0-Char ankommt.
Ansonsten ist das Vorgehen egal um was für einen String es sich handelt, mehr oder weniger gleich: Den Prozess mit ![]() ![]() ![]() ![]() Aber ohne genauere Angaben keine genaueren Informationen ;). |
Re: String mit ReadMemoryProcess auslesen
Also die Namen sind Dynamisch. Allerdings gibt es auch den einen oder anderen festen Wert der immer aus exakt 4 Buchstaben besteht. Dieser würde mir zu anfang genügen.
Was genau das für ein String ist kann ich leider nicht sagen, ich weiß nur das die original exe von 1998 ist und mit MS Visual C++ geschrieben wurde. |
Re: String mit ReadMemoryProcess auslesen
Bei C++ ist es am wahrscheinlichsten, daß die Strings nullterminiert sind. Schau halt mal mit nem Hex Editor in den Prozessspeicher wie die Strings aussehen. Dort solltest Du dann auch sehen ob es normale ANSI Strings sind oder Unicode Strings.
|
Re: String mit ReadMemoryProcess auslesen
Abgesehn vom ShortString und vielen CharArrays sind in Delphi auch alle Strings zusätzlich noch #0-terminiert, darum lassen sie sich so schön in PChar umwandeln,
also kann man meißt davon ausgehn, daß ein String vermutlich #0-terminiert sein wird, allerdings kannst du da im Speicher nicht so einfach rumschreiben, denn du weißt bestimmt nicht, wie die Speicherverwaltung der dynamischen Strukturen aussieht. |
Re: String mit ReadMemoryProcess auslesen
Die Strings sind in Unicode.
Ich habe mit dem Memory Editor Cheat Engine schon ein bisschen rumgespielt. Man kann die Namen ohne Probleme ändern, verlängern oder kürzen. Ist anscheiend Terminiert |
Re: String mit ReadMemoryProcess auslesen
*push*
|
Re: String mit ReadMemoryProcess auslesen
Wie vorzugehen ist, ist oben beschrieben. Magst Du etwa vollständigen Source haben?
|
Re: String mit ReadMemoryProcess auslesen
Wenn ich den String wie oben beschrieben auslese, kommen immer Integer werte dabei heraus.
|
Re: String mit ReadMemoryProcess auslesen
Ich weiß ja nicht was Du machst, aber wenn Du es so implementiert hättest, wie von mir geschrieben würd es funktionieren:
Delphi-Quellcode:
Prozess öffnen, ersten (Wide)Char lesen, an String anhängen, nächsten Char lesen, anhängen usw.. Als Abbruchbedingung dient entweder das terminierende Null-Char oder aber alternativ ein Lesefehler.
function ReadWideStringFromProcessMemory(PID : Cardinal; AddressOfString : Cardinal) : WideString;
var ProcessHandle : THandle; WideCharRead : WideChar; BytesRead : Cardinal; begin Result := ''; ProcessHandle := OpenProcess(PROCESS_VM_READ, FALSE, PID); if ProcessHandle <> INVALID_HANDLE_VALUE then begin repeat ReadProcessMemory(ProcessHandle, Pointer(AddressOfString), @WideCharRead, SizeOf(WideCharRead), BytesRead); Inc(AddressOfString, SizeOf(WideCharRead)); Result := Result + WideCharRead; until (Word(WideCharRead) = 0) or (BytesRead <> SizeOf(WideCharRead)); CloseHandle(ProcessHandle); end; end; |
Re: String mit ReadMemoryProcess auslesen
funktioniert prima dankeschön :-D
Aber vielleicht kannst du mir noch bei einer kleinen Sache helfen. Wenn kein Name vorhanden ist wird ja '' zurück gegeben. Jetzt möchte ich mit einer For Schleife erreichen das statt einem leeren Label dort das Wort 'Offline' erscheint. Ich habe es so probiert:
Delphi-Quellcode:
for i := 1 to 32 do
begin if Label[i].Caption = '' then begin Label[i].Caption := 'Offline'; end; inc(i); end; |
Re: String mit ReadMemoryProcess auslesen
Simpler wäre es wahrscheinlich die ReadWideStringFromProcessMemory Funktion anzupassen, so daß "Offline" zurückgegeben wird statt einem leeren String.
Delphi-Quellcode:
function ReadWideStringFromProcessMemory(PID : Cardinal; AddressOfString : Cardinal) : WideString;
var ProcessHandle : THandle; WideCharRead : WideChar; BytesRead : Cardinal; begin Result := ''; ProcessHandle := OpenProcess(PROCESS_VM_READ, FALSE, PID); if ProcessHandle <> INVALID_HANDLE_VALUE then begin repeat ReadProcessMemory(ProcessHandle, Pointer(AddressOfString), @WideCharRead, SizeOf(WideCharRead), BytesRead); Inc(AddressOfString, SizeOf(WideCharRead)); Result := Result + WideCharRead; until (Word(WideCharRead) = 0) or (BytesRead <> SizeOf(WideCharRead)); CloseHandle(ProcessHandle); end; if Result = '' then Result := 'Offline'; end; |
Re: String mit ReadMemoryProcess auslesen
Das wäre in dem Sinne zwar leichter, aber früher oder Später werde ich wieder vor diesem Problem stehen. Daher würde ich gerne wissen wie man soetwas in einer For Schleife realisieren kann.
|
Re: String mit ReadMemoryProcess auslesen
Dann übergeb den Default String der ausgegeben werden soll doch einfach als optionalen Parameter. Alles andere wäre aufwändiger, fehleranfälliger und meiner Meinung nach kein sonderlich tolles Code Design. Über den optionalen dritten Parameter kannst Du beim Aufruf also einfach 'Offline' mit übergeben und statt nem leeren String wird 'Offline' zurückgegeben.
Delphi-Quellcode:
function ReadWideStringFromProcessMemory(PID : Cardinal; AddressOfString : Cardinal; DefaultString : WideString = '') : WideString;
var ProcessHandle : THandle; WideCharRead : WideChar; BytesRead : Cardinal; begin Result := ''; ProcessHandle := OpenProcess(PROCESS_VM_READ, FALSE, PID); if ProcessHandle <> INVALID_HANDLE_VALUE then begin repeat ReadProcessMemory(ProcessHandle, Pointer(AddressOfString), @WideCharRead, SizeOf(WideCharRead), BytesRead); Inc(AddressOfString, SizeOf(WideCharRead)); Result := Result + WideCharRead; until (Word(WideCharRead) = 0) or (BytesRead <> SizeOf(WideCharRead)); CloseHandle(ProcessHandle); end; if Result = '' then Result := DefaultString; end; |
Re: String mit ReadMemoryProcess auslesen
Werde ich mal probieren! Danke
|
Alle Zeitangaben in WEZ +1. Es ist jetzt 07:52 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