博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
APC注入
阅读量:5327 次
发布时间:2019-06-14

本文共 535 字,大约阅读时间需要 1 分钟。

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

你可能感兴趣的文章
sqlserver 各种判断是否存在(表名、函数、存储过程等)
查看>>
给C#学习者的建议 - CLR Via C# 读后感
查看>>
Recover Binary Search Tree
查看>>
Java 实践:生产者与消费者
查看>>
[转]IOCP--Socket IO模型终结篇
查看>>
js 获取视频的第一帧
查看>>
各种正则验证
查看>>
观察者模式(Observer)
查看>>
python中numpy.r_和numpy.c_
查看>>
egret3D与2D混合开发,画布尺寸不一致的问题
查看>>
freebsd 实现 tab 命令 补全 命令 提示
查看>>
struts1和struts2的区别
查看>>
函数之匿名函数
查看>>
shell习题第16题:查用户
查看>>
Redis常用命令
查看>>
2018.11.06 bzoj1040: [ZJOI2008]骑士(树形dp)
查看>>
2019.02.15 bzoj5210: 最大连通子块和(链分治+ddp)
查看>>
redis cluster 集群资料
查看>>
微软职位内部推荐-Sr. SE - Office incubation
查看>>
微软职位内部推荐-SOFTWARE ENGINEER II
查看>>