Позвольте мне сказать, что это была моя первая попытка надлежащего чтения и записи в памяти. Функция записи еще не реализована, но она придет вовремя. Просто не плачь мне за код.Python - печать буфера строки ctype в приложении Read/WriteProcessMemory
Первым является полной программой, так что каждый может видеть (не комментировать мой «плохой выбор кодирования», вещь работ и я получаю дескриптор процесса и идентификатор просто отлично)
import ctypes
from ctypes import wintypes
from time import *
import win32ui, win32process ,win32api
PROCESS_ALL_ACCESS = 0x1F0FFF
ReadProcessMemory = ctypes.WinDLL('kernel32',use_last_error=True).ReadProcessMemory
ReadProcessMemory.argtypes = [wintypes.HANDLE,wintypes.LPCVOID,wintypes.LPVOID,ctypes.c_size_t,ctypes.POINTER(ctypes.c_size_t)]
ReadProcessMemory.restype = wintypes.BOOL
WriteProcessMemory = ctypes.WinDLL('kernel32',use_last_error=True).WriteProcessMemory
WriteProcessMemory.argtypes = [wintypes.HANDLE,wintypes.LPVOID,wintypes.LPCVOID,ctypes.c_size_t,ctypes.POINTER(ctypes.c_size_t)]
WriteProcessMemory.restype = wintypes.BOOL
def main():
WindowName = input("Enter the window name: ")
if (len(WindowName) > 0):
Process, pID = attach(WindowName)
Choice = input("Read or Write?").lower()
if (Choice == "write"):
#DoWriteMethod
pass
if (Choice == "read"):
Read(Process)
else:
print("Invalid Window Name!\n\n")
sleep(2)
return 0
def attach(WindowName):
try:
hWnd = win32ui.FindWindow(None,WindowName).GetSafeHwnd()
except:
print("Window not found!\n\n")
sleep(2)
return 0,0
pID = win32process.GetWindowThreadProcessId(hWnd)[1]
Process = win32api.OpenProcess(PROCESS_ALL_ACCESS,0,pID).handle
print("\nProcess = ", Process)
print("ProcessID = ", pID)
return Process,pID
def Write():
return 0
def Read(Process):
Address = input("Enter the address in hexadecial (0x form) \n")
if (Address[0] == "0" and Address[1] == "x"):
BufferAddress = ctypes.create_string_buffer(64)
ptr = ctypes.pointer(BufferAddress)
ReadProcessMemory(Process,Address,BufferAddress,64,None)
print("Pointer contains: ", BufferAddress, "\n\n")
main()
else:
print("Invalid address!\n\n")
sleep(2)
Read(Process)
return 0
if (main() == 0):
main()
if (main() == 1):
exit(0)
в строке 54 я создаю «ctype.create_string_buffer (64)»
то я использую это в ReadProcessMemory, где значение должно быть сохранено, но всякий раз, когда я печатаю его на линии 57 он просто возвращает следующее:
Enter the window name: New Tab - Google Chrome
Process = 608
ProcessID = 2844
Read or Write?Read
Enter the address in hexadecial (0x form)
0x1A6606BE380
Pointer contains: <ctypes.c_char_Array_64 object at 0x000001A0101D78C8>
Я знаю, что это значение должно быть 90 (найдено случайный адрес в чит-движке), поэтому оно должно содержать значение 90? Как я могу найти это значение.
Я использую Python 3.5.0 и соответствующий win32 модулей пакета от
'пункт установить pypiwin32'