吾爱破解 - 52pojie.cn

 找回密码
 注册[Register]

QQ登录

只需一步,快速开始

查看: 1455|回复: 3
收起左侧

[求助] 用易语言或者python怎么写exe基址

[复制链接]
杨氏 发表于 2020-3-10 16:49
用易语言或者python怎么写exe基址,如图是基址和三个偏移,如何写这种带有exe基址,求大佬给个教程
1.png

发帖前要善用论坛搜索功能,那里可能会有你要找的答案或者已经有人发布过相同内容了,请勿重复发帖。

729 发表于 2020-3-10 17:12
https://www.52pojie.cn/thread-912306-1-1.html  你可以参考一下这个文章 也许可以帮助到你

免费评分

参与人数 1吾爱币 +1 热心值 +1 收起 理由
ymhld + 1 + 1 我很赞同!

查看全部评分

wysyz 发表于 2020-3-10 17:22
古月不傲 发表于 2020-3-10 18:52
本帖最后由 古月不傲 于 2020-3-10 18:59 编辑

[C] 纯文本查看 复制代码
#include <iostream>
#include <Windows.h>

typedef enum _Address
{
	baseAddress = 0x007794F8,
	oneOffset = 0x868,
	twoOffset = 0x5578,
}Address;

//读取指定进程的内存
BOOL ReadProcessMem(
	_In_ HANDLE hProcess,
	_In_ PDWORD pBaseAddress,
	_In_ DWORD dwLayerOfOffset,
	_In_ PDWORD pOffsetBuffer,
	_In_ DWORD dwReadSize,
	_Out_ PVOID pReturnValue)
{
	if (hProcess == NULL || pBaseAddress == NULL || dwLayerOfOffset < 0) {
		return FALSE;
	}
	if (dwLayerOfOffset >= 1 && pOffsetBuffer == NULL) {
		return FALSE;
	}
	//没有偏移地址直接读取基地址返回
	if (dwLayerOfOffset == 0)
	{
		//读取基地址
		if (!ReadProcessMemory(hProcess, pBaseAddress, pReturnValue, dwReadSize, NULL)) {
			return FALSE;
		}
	}
	//有偏移地址的情况
	else
	{
		//读取基地址
		if (!ReadProcessMemory(hProcess, pBaseAddress, pReturnValue, sizeof(DWORD), NULL)) {
			return FALSE;
		}
		PVOID pAddress = NULL;
		//读取偏移
		for (DWORD dwCount = 0; dwCount < dwLayerOfOffset - 1; dwCount++)
		{
			pAddress = (PVOID)((*(PDWORD)pReturnValue) + pOffsetBuffer[dwCount]);
			if (!ReadProcessMemory(hProcess, pAddress, pReturnValue, sizeof(DWORD), NULL)) {
				return FALSE;
			}
		}
		pAddress = (PVOID)((*(PDWORD)pReturnValue) + pOffsetBuffer[dwLayerOfOffset - 1]);
		//读取最后偏移的值
		if (!ReadProcessMemory(hProcess, pAddress, pReturnValue, dwReadSize, NULL)) {
			return FALSE;
		}
	}

	return TRUE;
}

int main(void)
{
	DWORD processId = 0;
	HWND hWnd = FindWindow(NULL, TEXT("Plants vs. Zombies 1.2.0.1073 RELEASE"));
	GetWindowThreadProcessId(hWnd, &processId);
	HANDLE hProcess = OpenProcess(PROCESS_ALL_ACCESS, FALSE, processId);
	DWORD uOffsetBuffer[2] = { oneOffset, twoOffset };
	DWORD dwReturnValue = 0;
	if (ReadProcessMem(hProcess, (PDWORD)baseAddress, 2, uOffsetBuffer, 4, &dwReturnValue)) {
		printf("当前阳光值:%d\n", dwReturnValue);
	}

	system("pause");
	return 0;
}
您需要登录后才可以回帖 登录 | 注册[Register]

本版积分规则

返回列表

RSS订阅|小黑屋|处罚记录|联系我们|吾爱破解 - LCG - LSG ( 京ICP备16042023号 | 京公网安备 11010502030087号 )

GMT+8, 2024-11-30 06:13

Powered by Discuz!

Copyright © 2001-2020, Tencent Cloud.

快速回复 返回顶部 返回列表