龙马谷

 找回密码
 立即注册

QQ登录

只需一步,快速开始

龙马谷VIP会员办理客服QQ:82926983(如果临时会话没有收到回复,请先加QQ好友再发。)
1 [已完结] GG修改器新手入门与实战教程 31课 2 [已完结] GG修改器美化修改教程 6课 3 [已完结] GG修改器Lua脚本新手入门教程 12课
4 [已完结] 触动精灵脚本新手入门必学教程 22课 5 [已完结] 手游自动化脚本入门实战教程 9课 6 [已完结] C++射击游戏方框骨骼透视与自瞄教程 27课
7 [已完结] C++零基础UE4逆向开发FPS透视自瞄教程 29课 8 [已完结] C++零基础大漠模拟器手游自动化辅助教程 22课
以下是天马阁VIP教程,本站与天马阁合作,赞助VIP可以获得天马阁对应VIP会员,名额有限! 点击进入天马阁论坛
1 [已完结] x64CE与x64dbg入门基础教程 7课 2 [已完结] x64汇编语言基础教程 16课 3 [已完结] x64辅助入门基础教程 9课
4 [已完结] C++x64内存辅助实战技术教程 149课 5 [已完结] C++x64内存检测与过检测技术教程 10课 6 [已完结] C+x64二叉树分析遍历与LUA自动登陆教程 19课
7 [已完结] C++BT功能原理与x64实战教程 29课 8 [已完结] C+FPS框透视与自瞄x64实现原理及防护思路
查看: 1030|回复: 0

Windows驱动开发:内核特征码搜索函数封装

[复制链接]

28

主题

3

回帖

38

积分

编程入门

Rank: 1

龙马币
73
本章内容中将重点分析,并实现一个通用特征定位函数。

如下是一段特征码搜索片段,可以看到其实仅仅只是将上章中的搜索方式变成了一个SearchSpecialCode函数,如下函数,用户传入一个扫描起始地址以及搜索特征码的字节数组,即可完成搜索工作,具体的参数定义如下。

pSearchBeginAddr 扫描的内存(内核)起始地址
ulSearchLength 需要扫描的长度
pSpecialCode 扫描特征码,传入一个UCHAR类型的字节数组
ulSpecialCodeLength 特征码长度,传入字节数组长度

  1. // By: LyShark
  2. PVOID SearchSpecialCode(PVOID pSearchBeginAddr, ULONG ulSearchLength, PUCHAR pSpecialCode, ULONG ulSpecialCodeLength)
  3. {
  4.   PVOID pDestAddr = NULL;
  5.   PUCHAR pBeginAddr = (PUCHAR)pSearchBeginAddr;
  6.   PUCHAR pEndAddr = pBeginAddr + ulSearchLength;
  7.   PUCHAR i = NULL;
  8.   ULONG j = 0;

  9.   for (i = pBeginAddr; i <= pEndAddr; i++)
  10.   {
  11.     // 遍历特征码
  12.     for (j = 0; j < ulSpecialCodeLength; j++)
  13.     {
  14.       // 判断地址是否有效
  15.       if (FALSE == MmIsAddressValid((PVOID)(i + j)))
  16.       {
  17.         break;
  18.       }
  19.       // 匹配特征码
  20.       if (*(PUCHAR)(i + j) != pSpecialCode[j])
  21.       {
  22.         break;
  23.       }
  24.     }

  25.     // 匹配成功
  26.     if (j >= ulSpecialCodeLength)
  27.     {
  28.       pDestAddr = (PVOID)i;
  29.       break;
  30.     }
  31.   }
  32.   return pDestAddr;
  33. }
复制代码

游客,如果您要查看本帖隐藏内容请回复


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

本版积分规则

龙马谷| C/C++辅助教程| 安卓逆向安全| 论坛导航| 免责申明|Archiver|
拒绝任何人以任何形式在本论坛发表与中华人民共和国法律相抵触的言论,本站内容均为会员发表,并不代表龙马谷立场!
任何人不得以任何方式翻录、盗版或出售本站视频,一经发现我们将追究其相关责任!
我们一直在努力成为最好的编程论坛!
Copyright© 2018-2021 All Right Reserved.
在线客服
快速回复 返回顶部 返回列表