开启辅助访问 切换到宽版

精易论坛

 找回密码
 注册

QQ登录

只需一步,快速开始

用微信号发送消息登录论坛

新人指南 邀请好友注册 - 我关注人的新帖 教你赚取精币 - 每日签到


求职/招聘- 论坛接单- 开发者大厅

论坛版规 总版规 - 建议/投诉 - 应聘版主 - 精华帖总集 积分说明 - 禁言标准 - 有奖举报

查看: 309|回复: 7
收起左侧

[C/C++] 特征码模糊搜索通配符问题

[复制链接]
结帖率:50% (3/6)
发表于 2024-3-7 15:43:42 | 显示全部楼层 |阅读模式   江苏省常州市
10精币
下载.png
如图这是ce里面搜索的特征码
?8 ?? ?? ?? 00 00 00 00 40 ?? ?? ?? 00 00 00 00 04 00 00 00 ?? ?? ?? ?? FF
download.png
而在C++中我使用的是SunDay的算法 它只支持连续?? 不支持?8这种
求助各位大佬能否有办法实现如CE这样的搜法


回答提醒:如果本帖被关闭无法回复,您有更好的答案帮助楼主解决,请发表至 源码区 可获得加分喔。
友情提醒:本版被采纳的主题可在 申请荣誉值 页面申请荣誉值,获得 1点 荣誉值,荣誉值可兑换荣誉会员、终身vip用户组。
快捷通道:申请荣誉值无答案申请取消悬赏投诉有答案未采纳为最佳

签到天数: 10 天

发表于 2024-3-7 16:21:50 | 显示全部楼层   浙江省丽水市
08 18 28 ---- F8   哈哈哈哈
回复

使用道具 举报

结帖率:100% (4/4)

签到天数: 7 天

发表于 2024-3-7 16:40:36 | 显示全部楼层   河南省焦作市
换一种方法
回复

使用道具 举报

结帖率:100% (77/77)

签到天数: 27 天

发表于 2024-3-7 19:21:22 | 显示全部楼层   河南省洛阳市
?号 支持不支持 得看你算法里自己写的匹配是啥吧?
回复

使用道具 举报

结帖率:50% (3/6)

签到天数: 17 天

 楼主| 发表于 2024-3-7 22:04:48 | 显示全部楼层   江苏省常州市
风度猫 发表于 2024-3-7 19:21
?号 支持不支持 得看你算法里自己写的匹配是啥吧?

我这个算法不支持?8 但是支持?? 所以我发帖问一下有没有?8支持这种的算法
回复

使用道具 举报

结帖率:100% (77/77)

签到天数: 27 天

发表于 2024-3-7 22:10:39 | 显示全部楼层   河南省洛阳市
小白白白白白啊 发表于 2024-3-7 22:04
我这个算法不支持?8 但是支持?? 所以我发帖问一下有没有?8支持这种的算法
  
#include
#include
#include
#include

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& 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& 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 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::iterator it = ResultArray.begin (); it != ResultArray.end (); it++)
{
printf ("%x\n", *it);
}

return 0;
}
</endl;

<endl;
自行脑补</endl;

回复

使用道具 举报

结帖率:50% (3/6)

签到天数: 17 天

 楼主| 发表于 2024-3-8 14:26:36 | 显示全部楼层   江苏省常州市
风度猫 发表于 2024-3-7 22:10
[e=0]#include
#include
#include

这个算法就是我从网上找的 一模一样 好像不支持?8
回复

使用道具 举报

签到天数: 19 天

发表于 2024-4-1 11:21:40 | 显示全部楼层   内蒙古自治区鄂尔多斯市
改一下特征码。把?8改成??。。如果要检查?8相当于一个字节的数字还要拆分成2个数进行比对。效率上也不行。
回复

使用道具 举报

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

本版积分规则 致发广告者

发布主题 收藏帖子 返回列表

sitemap| 易语言源码| 易语言教程| 易语言论坛| 诚聘英才| 易语言模块| 手机版| 广告投放| 精易论坛
拒绝任何人以任何形式在本论坛发表与中华人民共和国法律相抵触的言论,本站内容均为会员发表,并不代表精易立场!
论坛帖子内容仅用于技术交流学习和研究的目的,严禁用于非法目的,否则造成一切后果自负!如帖子内容侵害到你的权益,请联系我们!
防范网络诈骗,远离网络犯罪 违法和不良信息举报电话0663-3422125,QQ: 800073686,邮箱:800073686@b.qq.com
Powered by Discuz! X3.4 揭阳市揭东区精易科技有限公司 ( 粤ICP备12094385号-1) 粤公网安备 44522102000125 增值电信业务经营许可证 粤B2-20192173

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