C++内存搜索特征码

[复制链接]
ad***官方认证 发表于 2022-7-27 10:31:10 | 显示全部楼层 |阅读模式
ad*** 2022-7-27 10:31:10 1435 1 显示全部楼层

注册账号-全站资源免费下载

您需要 登录 才可以下载或查看,没有账号?注册账号

x
[C] 纯文本查看 复制代码
#pragma once
#include <windows.h>
#include <string>
#include <vector>

namespace FeatureFunc
{
	/*
		??通配符
		Demo:
			FeatureFunc::Find(Module,"48 E8 CC ?? 05 FF")
	*/
	DWORD64 Find(DWORD64 Module, std::string Feature)
	{
		// 去空
		for (int i = 0; i < Feature.length(); i++)
		{
			if (Feature[i] == ' ')
				Feature.replace(i, 1, "");
		}

		if (Feature.size() < 2)
			return 0;

		if (Feature.size() % 2 != 0)
			return 0;

		std::vector<std::pair<bool, byte>> Bytes;

		// 字节、掩码生成
		for (int i = 0; i < Feature.length(); i += 2)
		{
			if (Feature.substr(i, 2) == "??")
				Bytes.push_back(std::make_pair<bool, byte>(false, 0x0));
			else
				Bytes.push_back(std::make_pair<bool, byte>(true, static_cast<byte>(std::stol(Feature.substr(i, 2), 0, 16))));
		}

		// 校对
		PIMAGE_DOS_HEADER pImageDos = reinterpret_cast<PIMAGE_DOS_HEADER>(Module);
		PIMAGE_NT_HEADERS32 pImageNt = reinterpret_cast<PIMAGE_NT_HEADERS32>(Module + pImageDos->e_lfanew);
		DWORD Length = pImageNt->OptionalHeader.SizeOfImage - Bytes.size();

		for (int Offset = 0; Offset < Length; Offset++)
		{
			if (!IsBadHugeReadPtr(reinterpret_cast<PVOID>(Module + Offset), 1))
			{
				byte* pTempByte = reinterpret_cast<byte*>(Module + Offset);
				int ProofNum = 0;

				for (auto SingleByte : Bytes)
				{
					if (SingleByte.first && SingleByte.second != *pTempByte)
						break;
					pTempByte++;
					ProofNum++;
				}

				if (ProofNum == Bytes.size() && *pTempByte)
					return Module + Offset;
			}
		}
		return NULL;
	}
}





上一篇:【易源码】雷电模拟器中控源码2.1
下一篇:CF新不掉血 无线喷漆 空格连跳开源
这个家伙很赖,还没有设置签名
dj*** 发表于 2022-11-4 22:00:30 | 显示全部楼层
dj*** 2022-11-4 22:00:30 显示全部楼层
为什么本论坛WIN源码跟手机源码不分开呢??
这个家伙很赖,还没有设置签名
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 注册账号

本版积分规则 返回列表 发新帖

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