龙马谷

 找回密码
 立即注册

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课 9 [已完结] C++零基础开发DXF内存脚本辅助教程 32课
以下是天马阁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实现原理及防护思路
查看: 4334|回复: 0

分享反上传以及扫描文件 HOOK ZwCreateFile源码

[复制链接]

13

主题

1

回帖

18

积分

编程入门

Rank: 1

龙马币
36

分享反上传以及扫描文件 HOOK ZwCreateFile源码

  1. NTSTATUS __stdcall NewZwCreateFile(
  2.         OUT PHANDLE             FileHandle,
  3.         IN ACCESS_MASK          DesiredAccess,
  4.         IN POBJECT_ATTRIBUTES   ObjectAttributes,
  5.         OUT PVOID    IoStatusBlock,
  6.         IN PLARGE_INTEGER       AllocationSize OPTIONAL,
  7.         IN ULONG                FileAttributes,
  8.         IN ULONG                ShareAccess,
  9.         IN ULONG                CreateDisposition,
  10.         IN ULONG                CreateOptions,
  11.         IN PVOID                EaBuffer OPTIONAL,
  12.         IN ULONG                EaLength)
  13. {
  14.         NTSTATUS status;
  15.         ZwCreateFile_1 OldZwCreateFile;
  16.         WCHAR lpwzDllName[260] = {0};
  17.         WCHAR lpAttackDll[5][260] = {L"1",L"2",L"3",L"4"};//要保护的东西名称     当然你可以自己想办法过滤不是游戏和系统的东西全部给我禁止访问

  18.         __try{
  19.                 if (IsBadReadPtr(ObjectAttributes,sizeof(OBJECT_ATTRIBUTES)) == 0)
  20.                 {
  21.                         if (ValidateUnicodeString(ObjectAttributes->ObjectName))
  22.                         {
  23.                                 //效验unicode的有效性
  24.                                 if (ObjectAttributes->ObjectName->Buffer != NULL &&
  25.                                         ObjectAttributes->ObjectName->Length > 6)
  26.                                 {
  27.                                         memcpy(lpwzDllName,ObjectAttributes->ObjectName->Buffer,ObjectAttributes->ObjectName->Length);
  28.                                         if (wcsstr(lpwzDllName,lpAttackDll[0]) != 0 ||
  29.                                                 wcsstr(lpwzDllName,lpAttackDll[1]) != 0 ||
  30.                                                 wcsstr(lpwzDllName,lpAttackDll[2]) != 0 ||
  31.                                                 wcsstr(lpwzDllName,lpAttackDll[3]) != 0)
  32.                                         {
  33.                                                 //拒绝访问
  34.                                                 return STATUS_ACCESS_DENIED;
  35.                                         }
  36.                                 }
  37.                         }
  38.                 }
  39.         }__except(1){

  40.         }
  41.         OldZwCreateFile = (ZwCreateFile_1)ZwCreateFileHookZone;
  42.         status = OldZwCreateFile(FileHandle,
  43.                 DesiredAccess,
  44.                 ObjectAttributes,
  45.                 IoStatusBlock,
  46.                 AllocationSize,
  47.                 FileAttributes,
  48.                 ShareAccess,
  49.                 CreateDisposition,
  50.                 CreateOptions,
  51.                 EaBuffer,
  52.                 EaLength);

  53.         return status;
复制代码

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

本版积分规则

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