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]
[kernel32 ReadProcessMemory]问题出在哪里?
- 写回答
- 好问题 0 提建议
- 追加酬金
- 关注问题
- 邀请回答
-
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 网页视频播放,无法播放