求大佬修改一下一个C++程序 - 爱问答

(爱问答)

求大佬修改一下一个C++程序

我想将这程序修改成dll,接收参数2个
参数1:进程PID
参数2:特征码
下边这个程序是网上大佬分享的
#include<Windows.h>
#include<iostream>
#include<vector>
#include<time.h>

using namespace std;

#define BLOCKMAXSIZE 409600//每次读取内存的最大大小
BYTE* MemoryData;//每次将读取的内存读入这里
short Next[260];

//特征码转字节集
word GetTzmArray(char* Tzm, word* TzmArray)
{
int len = 0;
WORD TzmLength = strlen(Tzm) / 3 + 1;

for (int 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 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 SearchMemoryBlock(HANDLE hProcess, WORD* Tzm, WORD TzmLength, unsigned __int64 StartAddress, unsigned long size, vector<unsigned __int64>& ResultArray)
{
if (!ReadProcessMemory(hProcess, (LPCVOID)StartAddress, MemoryData, size, NULL))
{
return;
}

for (int 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)
{
return;
}

int num = Next[MemoryData[i + TzmLength]];
if (num == -1)
i += (TzmLength - Next[256]);//如果特征码有问号,就从问号处开始匹配,如果没有就i+=-1
else
i += (TzmLength - num);
}
}

//搜索整个程序
int SearchMemory(HANDLE hProcess, char* Tzm, unsigned __int64 StartAddress, unsigned __int64 EndAddress, int InitSize, vector<unsigned __int64>& ResultArray)
{
int i = 0;
unsigned long BlockSize;
MEMORY_BASIC_INFORMATION mbi;

WORD TzmLength = strlen(Tzm) / 3 + 1;
WORD* TzmArray = new WORD[TzmLength];

GetTzmArray(Tzm, TzmArray);
GetNext(Next, TzmArray, TzmLength);

//初始化结果数组
ResultArray.clear();
ResultArray.reserve(InitSize);

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)
{
return ResultArray.size();
}
}
free(TzmArray);
return ResultArray.size();
}

int main()
{
//初始化MemoryData大小
MemoryData = new BYTE[BLOCKMAXSIZE];

DWORD pid=0;
vector<unsigned __int64> ResultArray;
cout << "请输入进程ID:" << endl;
cin >> pid;

//通过进程ID获取进程句柄
HANDLE hProcess = OpenProcess(PROCESS_ALL_ACCESS, false, pid);

int start = clock();
SearchMemory(hProcess, (char*)"FF 3F FF ?? FF F2", 0x410000, 0xFFFFFFFF, 30, ResultArray);
int end = clock();

cout << "用时:" << end-start << "毫秒"<<endl;
cout << "搜索到" << ResultArray.size() << "个结果" << endl;

for (vector<unsigned __int64>::iterator it = ResultArray.begin(); it != ResultArray.end(); it++)
{
printf("%x ", *it);
}

return 0;
}

将一个完整的可运行C++程序改为dll,对任何一个程序员,都是非常简单的事 

但你要注意的是

1.你要按你的开发工具,选生成目标为dll

2,你的导出要有输出项(dll不支持控制台输出的)

对你的可改程序中的main()为

__declspec(dllexport) void  SearchMemory_d(DWORD pid, char *keys,int *times,unsigned __int64 *ret) { //初始化MemoryData大小 MemoryData = new BYTE[BLOCKMAXSIZE]; vector<unsigned __int64> ResultArray; /* cout << "请输入进程ID:" << endl; cin >> pid; */ //通过进程ID获取进程句柄 HANDLE hProcess = OpenProcess(PROCESS_ALL_ACCESS, false, pid); int start = clock(); SearchMemory(hProcess, keys, 0x410000, 0xFFFFFFFF, 30, ResultArray); int end = clock(); /* cout << "用时:" << end-start << "毫秒"<<endl; cout << "搜索到" << ***.size() << "个结果" << endl; */ *times=end-start ; for (vector<unsigned __int64>::iterator it = ***.begin(); it != ResultArray.end(); it++) { //printf("%x ", *it);   *ret++=*it; } //return 0; }

其中,SearchMemory_d为DLL导出函数,前两个参数为进程PID和特征码,times为返回的搜索用时,而ret为结果(要注意给它们足够的空间)

下一篇:xlsx表格中如何插入不可见字符

上一篇:java如何实现通过方法重载输入

热门标签:
excel 网盘 破解 word dll
最新更新:
微软重新评估新的Outlook的使用时机 联想推出搭载联发科Helio G80芯片组的Tab M9平板 英特尔创新大赛时间确定! 微软Edge浏览器在稳定渠道中推出Workspaces功能 英伟达RTX4060TiGPU推出MaxSun动漫主题! 谷歌地图为用户提供了街景服务! GameSir 在T4 Kaleid中推出了一款出色的控制器! 微软开始在Windows 11 中测试其画图应用程序的新深色模式! LG电子推出全球首款无线OLED电视 英伟达人工智能芯片崭露头角! Steam Deck可以玩什么游戏-Steam Deck价格限时优惠 雷蛇推出CobraPro鼠标 Kindle电子阅读器可以访问谷歌商店吗 Windows10如何加入组策略 window10图片查看器怎么没有了?