m0_57901298 2021-05-25 14:10 采纳率: 58.3%
浏览 30

[kernel32 ReadProcessMemory]问题出在哪里?

def findaddr(process_handle, basic, one, two):
	data1 = ctypes.c_long()
	kernel32.ReadProcessMemory(int(process_handle), basic, ctypes.byref(data1), 4, None)
	data2 = ctypes.c_long()
	kernel32.ReadProcessMemory(int(process_handle), data1.value + one, ctypes.byref(data2), 4, None)
	return data2.value + two

def findaddrplus(process_handle, basic, one, two, three):
	data1 = ctypes.c_long()
	kernel32.ReadProcessMemory(int(process_handle), basic, ctypes.byref(data1), 4, None)
	data2 = ctypes.c_long()
	kernel32.ReadProcessMemory(int(process_handle), data1.value + one, ctypes.byref(data2), 4, None)
	data3 = ctypes.c_long()
	kernel32.ReadProcessMemory(int(process_handle), data2.value + two, ctypes.byref(data3), 4, None)
	return data3.value + three

这是我的屎山代码,所以我要改进它,但它失效了.

def findaddr(process_handle, basic, *offsets):
	data = ctypes.c_long()
	kernel32.ReadProcessMemory(int(process_handle), basic, ctypes.byref(data), 4, None)
	for i in range(len(offsets) - 1):
		kernel32.ReadProcessMemory(int(process_handle), data.value + offsets[i - 1], ctypes.byref(data), 4, None)
	return data.value + offsets[-1]
  • 写回答

1条回答 默认 最新

  • devid008 2023-03-25 08:36
    关注

    这个代码的问题可能出在这一行:

    kernel32.ReadProcessMemory(int(process_handle), data.value + offsets[i - 1], ctypes.byref(data), 4, None)
    
    

    在第一次迭代时,当 i = 0 时,offsets[i - 1] 会访问列表 offsets 的最后一个元素。这可能导致访问越界的问题。

    您可以将该行代码更改为:

    kernel32.ReadProcessMemory(int(process_handle), data.value + offsets[i], ctypes.byref(data), 4, None)
    
    

    这样就会使用正确的偏移量进行读取。

    评论

报告相同问题?

悬赏问题

  • ¥15 (标签-3D|关键词-色模型)
  • ¥15 发现在MSVS2022中”#pragma once“不起作用
  • ¥15 实时声纹降噪算法进行无关说话人语音抑制
  • ¥15 Python如何爬取post请求头的数据
  • ¥100 adb针对解决手机锁屏问题(相关搜索:手机锁屏)
  • ¥15 发现哔哩哔哩的粉丝只能显示前5页能不能爬出来
  • ¥15 oracle数据库求解
  • ¥15 c++ websocketpp连接币安 有报错,有偿求解
  • ¥20 提供开发板完整sdk文件,升级开发板函数库
  • ¥15 网页视频播放,无法播放