可以搜索内存,包括模拟器内存。
SearchMemer.h
#pragma once
#include <vector>
#define BLOCKMAXSIZE 409600//每次读取内存的最大大小
class SearchMember
{
public:
SearchMember();
~SearchMember();
private:
BYTE* MemoryData;//每次将读取的内存读入这里
//初始化MemoryData大小
//BYTE* MemoryData = new BYTE[BLOCKMAXSIZE];
short Next[260];
public:
void SearchMemoryBlock(HANDLE hProcess, WORD* Tzm, WORD TzmLength, unsigned __int64 StartAddress, unsigned long size, std::vector<unsigned __int64>& ResultArray);
int SearchMemory(HANDLE hProcess, char* Tzm, unsigned __int64 StartAddress, unsigned __int64 EndAddress, int InitSize, std::vector<unsigned __int64>& ResultArray);
BOOL TzmAddSpace(CStringA& strTzm);
WORD GetTzmArray(char* Tzm, WORD* TzmArray);
void GetNext(short* next, WORD* Tzm, WORD TzmLength);
};
SearchMemer.cpp
//https://www.cnblogs.com/LyShark/p/15019490.html
#include "stdafx.h"
#include "SearchMemer.h"
//using namespace std;
SearchMember::SearchMember()
{
}
SearchMember::~SearchMember()
{
}
//特征码转字节集
WORD SearchMember::GetTzmArray(char* Tzm, WORD* TzmArray)
{
int len = 0;
WORD TzmLength = (WORD)strlen(Tzm) / 3 + 1;
for (UINT i = 0; i < strlen(Tzm); )//将十六进制特征码转为十进制
{
char num[2];
num[0] = Tzm[i++];
num[1] = Tzm[i++];
i++;
if (num[0] != '?' && num[1] != '?')
{
int sum = 0;
WORD a[2];
for (int i = 0; i < 2; i++)
{
if (num[i] >= '0' && num[i] <= '9')
{
a[i] = num[i] - '0';
}
else if (num[i] >= 'a' && num[i] <= 'z')
{
a[i] = num[i] - 87;
}
else if (num[i] >= 'A' && num[i] <= 'Z')
{
a[i] = num[i] - 55;
}
}
sum = a[0] * 16 + a[1];
TzmArray[len++] = sum;
}
else
{
TzmArray[len++] = 256;
}
}
return TzmLength;
}
//获取Next数组
void SearchMember::GetNext(short* next, WORD* Tzm, WORD TzmLength)
{
//特征码(字节集)的每个字节的范围在0-255(0-FF)之间,256用来表示问号,到260是为了防止越界
for (int i = 0; i < 260; i++)
next[i] = -1;
for (int i = 0; i < TzmLength; i++)
next[Tzm[i]] = i;
}
//搜索一块内存
void SearchMember::SearchMemoryBlock(HANDLE hProcess, WORD* Tzm, WORD TzmLength, unsigned __int64 StartAddress, unsigned long size, std::vector<unsigned __int64>& ResultArray)
{
MemoryData = new BYTE[BLOCKMAXSIZE];
if (!ReadProcessMemory(hProcess, (LPCVOID)StartAddress, MemoryData, size, NULL))
{
delete[] MemoryData;
return;
}
for (UINT i = 0, j, k; i < size;)
{
j = i; k = 0;
for (; k < TzmLength && j < size && (Tzm[k] == MemoryData[j] || Tzm[k] == 256); k++, j++);
if (k == TzmLength)
{
ResultArray.push_back(StartAddress + i);
}
if ((i + TzmLength) >= size)
{
delete[] MemoryData;
return;
}
int num = Next[MemoryData[i + TzmLength]];
if (num == -1)
i += (TzmLength - Next[256]);//如果特征码有问号,就从问号处开始匹配,如果没有就i+=-1
else
i += (TzmLength - num);
}
delete[] MemoryData;
}
//搜索整个程序
int SearchMember::SearchMemory(HANDLE hProcess, char* Tzm, unsigned __int64 StartAddress, unsigned __int64 EndAddress, int InitSize, std::vector<unsigned __int64>& ResultArray)
{
int i = 0;
unsigned long BlockSize;
MEMORY_BASIC_INFORMATION mbi;
WORD TzmLength = (WORD)strlen(Tzm) / 3 + 1;
WORD* TzmArray = new WORD[TzmLength];
GetTzmArray(Tzm, TzmArray);
GetNext(Next, TzmArray, TzmLength);
//初始化结果数组
ResultArray.clear();
ResultArray.reserve(InitSize);
try
{
while (VirtualQueryEx(hProcess, (LPCVOID)StartAddress, &mbi, sizeof(mbi)) != 0)
{
//获取可读可写和可读可写可执行的内存块
if (mbi.Protect == PAGE_READWRITE || mbi.Protect == PAGE_EXECUTE_READWRITE)
{
i = 0;
BlockSize = mbi.RegionSize;
//搜索这块内存
while (BlockSize >= BLOCKMAXSIZE)
{
SearchMemoryBlock(hProcess, TzmArray, TzmLength, StartAddress + (BLOCKMAXSIZE * i), BLOCKMAXSIZE, ResultArray);
BlockSize -= BLOCKMAXSIZE; i++;
}
SearchMemoryBlock(hProcess, TzmArray, TzmLength, StartAddress + (BLOCKMAXSIZE * i), BlockSize, ResultArray);
}
StartAddress += mbi.RegionSize;
if (EndAddress != 0 && StartAddress > EndAddress)
{
free(TzmArray);
return ResultArray.size();
}
}
DWORD err = GetLastError();
}
catch (...)
{
AfxMessageBox(L"SearchMemory err");
}
free(TzmArray);
return ResultArray.size();
}
BOOL SearchMember::TzmAddSpace(CStringA& strTzm)
{
if (strTzm.Find(" ") > 0)
{
return TRUE;
}
CStringA strNew;
for (int i = 0; i < strTzm.GetLength(); i++)
{
strNew.Append(CStringA(strTzm.GetAt(i)));
if (i != 0 && (i + 1) % 2 == 0)
{
strNew.Append(" ");
}
}
strNew.Trim();
strTzm = strNew;
return TRUE;
}
调用:
CStringA strTemp = "210000000F000000????????D5DCA4C5";
SearchMember sm;
sm.TzmAddSpace(strTemp);
sm.SearchMemory(hProcess, strTemp.GetBuffer(strTemp.GetLength()), 0x1001B02E, 0x6FFFFFFF, 1, ResultArray);
strTemp.ReleaseBuffer();