【逆向】Windows 三大注入:远程线程 、APC 、 钩子注入

一、远程线程注入(CreateRemoteThread)

实现流程

  1. 打开目标进程,获取PROCESS_ALL_ACCESS权限
  2. 在目标进程VirtualAllocEx申请可写可执行内存
  3. WriteProcessMemory写入 DLL 路径
  4. 获取LoadLibraryA/W地址
  5. CreateRemoteThread创建远程线程,回调为 LoadLibrary
  6. 线程执行后加载 DLL,完成注入

优缺点

  • 优点:实现最简单、兼容性最好、稳定通用
  • 缺点:易被检测、无法注入系统进程、不支持跨会话

触发条件

  • 目标进程有足够权限
  • 未被保护、未开启强反注入

对抗手段

  • Hook NtCreateThreadEx
  • 监控远程线程创建
  • 校验新线程起始地址是否为 LoadLibrary
  • 阻止非信任进程打开句柄

二、APC 注入(异步过程调用)

实现流程

  1. 打开目标进程,分配内存并写入 DLL 路径
  2. 枚举目标线程OpenThread
  3. QueueUserAPC将 APC 插入线程队列
  4. 回调函数设为 LoadLibrary
  5. 线程进入alertable wait状态时自动执行 APC

优缺点

  • 优点:无新线程、隐蔽性更高,可绕过部分远程线程检测
  • 缺点:依赖线程进入可等待状态,不一定立即执行,不稳定

触发条件

  • 线程必须进入 alertable 状态(Sleep、WaitForSingleObjectEx 等)
  • 不能被内核强制阻断 APC

对抗手段

  • 监控NtQueueApcThread
  • 过滤 APC 回调是否为 LoadLibrary
  • 禁用用户 APC 或清空 APC 队列
  • 检测内存中突然出现的 DLL 路径

三、钩子注入(SetWindowsHookEx)

实现流程

  1. 编写带Hook 回调的 DLL
  2. SetWindowsHookEx设置全局钩子(WH_KEYBOARD、WH_MOUSE、WH_CALLWNDPROC 等)
  3. 系统会自动把 DLL 映射到所有接收消息的 GUI 进程
  4. 目标进程触发消息时执行注入逻辑

优缺点

  • 优点:全局注入、GUI 场景天然稳定,适合桌面软件
  • 缺点:只支持有消息循环的 GUI 进程,无法注入控制台/无窗口进程

触发条件

  • 目标进程是 GUI 进程、有消息循环
  • 未取消钩子、未屏蔽窗口消息

对抗手段

  • Hook SetWindowsHookEx
  • 卸载不明钩子、枚举钩子列表
  • 禁止加载未知 DLL
  • GUI 进程强化模块白名单

面试速记版(一句话总结)

  1. 远程线程:最简单最稳,但最容易被查。
  2. APC:更隐蔽,但靠运气执行,不稳定。
  3. 钩子:只适合 GUI,全局生效但局限大。
相关推荐
感谢地心引力3 分钟前
在codex里面使用Deepseek-v4,支持mac和windows双系统
windows·gpt·macos·ai·codex·deepseek
不总是9 小时前
Windows 系统 Node.js 免安装版(zip)安装与配置教程(2026 最新)
前端·windows·node.js
不总是12 小时前
[2026最新] Windows 免安装版 MySQL 8 详细安装配置教程(ZIP 压缩包版)
数据库·windows·mysql
2401_8769641313 小时前
27考研余炳森概率论|喻老李良2027资料网课
windows·git·考研·svn·eclipse·github·概率论
介一安全13 小时前
【漏洞学习】PHP+Windows环境通用文件上传漏洞深度剖析
windows·web安全·php·文件上传·安全性测试
思麟呀13 小时前
C++工业级日志项目(六)异步日志器
linux·c++·windows
fastjson_14 小时前
Win11 关闭拖动窗口自动出现的贴靠窗口分栏
windows
早睡身体真不戳14 小时前
【无标题】
java·服务器·windows
不总是14 小时前
JDK17在Windows 系统 安装与环境变量配置
windows
fastjson_16 小时前
Windows11 无法删除文件,提示:你需要 SYSTEM 提供的权限才能对此文件进行更改
windows