APC注入

APC注入技术解析
本文深入探讨了APC注入技术,介绍了APC如何允许线程在正常执行前运行额外代码,分为内核APC和用户APC两种形式。在用户模式下,QueueUserAPC可用于远程线程调用,加载恶意DLL;内核模式下,则涉及KeInitializeAPC和KeInsertQueueAPC函数。文章详细阐述了这两种模式下的具体操作。
APC注入可以让一个线程在它正常的执行路径运行之前执行一些其他的代码,每一个线程都有一个附加的APC队列,他们在线程处于可警告的时候才被处理(WaitForSingObjectEx,SleepEx)
如果程序在线程可警告等待状态时候排入一个APC队列,那么线程将开始执行APC函数,恶意代码则可以设置APC函数抢占可警告等待状态的线程。
APC有两种存在形式:
1.为系统和驱动生成的APC(内核APC)
2.为应用程序生成的APC(用户APC)
 
用户模式:
   线程可利用QueueUserAPC排入一个让远程线程调用的函数,QueueUser函数的参数 pfnAPC,hThread,dwDate用法如下:
一旦获取了线程ID,就可以利用其打开句柄,通过参数LoadLibaryA以及对应参数dwData(dll名称),LoadLibaryA就会被远程线程调用, 从而加载对应的恶意DLL
 
内核模式:

 

需要两个函数来搭配使用,构造APC函数
KeInitializeAPC(初始化KAPC结构)
KeInsertQueueAPC(将APC对象放入目标线程的APC对列中)

 

转载于:https://www.cnblogs.com/Tempt/p/9988232.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值