【逆向】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,全局生效但局限大。
相关推荐
qq_369224332 天前
Windows全系通用!ntdll.dll文件丢失、报错、闪退问题的完整排查与修复教程
windows·dll·dll修复·dll丢失·dll错误
阿米亚波3 天前
【Windows】QEMU 启动 openEuler aarch64/arm64 架构系统 + 离线软件源
linux·windows·经验分享·笔记·架构·arm
caimouse3 天前
Reactos 第 10 章 网络操作 — 10.3.1 NIC驱动
网络·windows
初圣魔门首席弟子3 天前
Node.js 详细介绍(知识库版)
windows·qt·node.js·知识库
CHENG-JustDoIt3 天前
AI工具 | 爆火开源项目Odysseus AI 工作台:从项目介绍、部署情况及其使用等多方位分析指南(含详细步骤)
大数据·人工智能·windows·python·ai·开源·github
kingbal3 天前
Windows:flutter环境搭建
windows·flutter
未若君雅裁3 天前
Python 数据容器详解,list、tuple、str、set、dict 到底怎么选
windows·python·list
CodeKwang3 天前
Windows 环境 OCCT 8.0 编译构建及与 Qt6 项目集成
windows·qt·opencascade
我是伪码农3 天前
小兔鲜1-25
linux·服务器·windows
vx-Biye_Design3 天前
springboot安阳地区研学旅游服务小程序-计算机毕业设计源码12785
java·vue.js·windows·spring boot·tomcat·maven·mybatis