对程序调用API变形的一点认识

我就从简单分析下怎样躲过杀毒软件的查杀说起吧

这是我以前的文章,据说这种技术可以过主动防御

. 386
.Model Flat, StdCall
Option Casemap :None

Include windows.inc
Include user32.inc
Include kernel32.inc
IncludeLib user32.lib
IncludeLib kernel32.lib

.DATA
szDllKernel db 
' user32.dll ' , 0
szMessageBox db 
' MessageBoxA ' , 0

.DATA
?
lpMessageBox dd 
?
.CODE
START:
invoke GetModuleHandle,addr szDllKernel
mov ebx,eax
invoke GetProcAddress,ebx,offset szMessageBox
mov lpMessageBox,eax
push MB_OK
push 
0
push 
0
push 
0
mov EAX,offset _END
push EAX
jmp lpMessageBox
_END:
invoke ExitProcess,
0

END START

 上面的代码可用于反杀毒软件的病毒里,杀毒软件一般都用特征码判断是否调用了危险API,而上面的代码就是把CALL分解开来,实现了简单的代码变形
如果杀毒软件是靠判断JMP的目标是否为危险API的话,也可以写成这样躲过杀毒软件

 

.CODE
START:
invoke GetModuleHandle,addr szDllKernel
mov ebx,eax
invoke GetProcAddress,ebx,offset szMessageBox
mov lpMessageBox,eax
push MB_OK
push 
0
push 
0
push 
0
mov EAX,offset _END
push EAX
;添加的代码开始
mov edi,edi
push ebp
mov ebp,esp
add lpMessageBox,
5
;添加的代码结束
jmp lpMessageBox
_END:
invoke ExitProcess,
0  
END START

 

杀毒软件一般是靠特征码判断病毒的,比如杀毒软件监视MessageBox这个函数的调用,只要调用这个函数杀毒软件就认为你有破坏系统的动机,所以我们就得想办法躲过杀毒软件的监视,但又不能不用这个函数那怎么办呢?
www.xbin.cn
了解调用过程的人都知道CALL指令就是先把下一条指令地址压栈然后在用JMP跳转到函数入口处,那我们的解决办法就出来了,我们可以自己完成这个调用动作,先把下一条指令压栈

 

mov EAX,offset _END
push EAX

 

在跳转到函数入口处

 

jmp lpMessageBox 

 

这样就骗过杀毒软件了,因为在二进制代码级别上,上面的代码和CALL指令的二进制是不同的,但实现的功能是相同的。

有的杀毒软件不光靠判断特征码,而且还判断跳转的目标地址,就是判断你的指令是否跳转到他认为危险的API入口处,当然我们也有办法骗过他,那就是把目标API的前几行代码在自己程序里实现,然后在跳转到API函数中去继续运行。比如我是把MessageBox的前3行代码在自己的程序里实现,然后在条到MessageBox的第4行里继续运行。
www.xbin.cn
这样跳转到目标入口地址就不是API函数的入口了

如果杀毒软件是靠判断是否跳转到一个指定的区域的话,那还有一个更毒的招,那就是分配一个动态内存,把API函数代码考到自己的2G空间里运行

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
驱动程序调用应用层API是指系统的驱动程序通过调用应用层API来完成特定功能。驱动程序是一种软件,用于控制硬件设备的操作和管理。而应用层API(Application Programming Interface,应用程序接口)则是一组预先定义好的函数和方法,用于提供给开发者使用的接口。 驱动程序通过调用应用层API来实现与应用程序的交互。通过调用API中的函数或方法,驱动程序可以向上层应用程序提供各种操作硬件设备的功能。比如,一个打印机驱动程序可以通过调用应用层API中的打印函数,将应用程序中的打印任务发送给打印机设备进行打印。驱动程序可以通过调用API中的函数来控制设备的开关、设置设备参数、读取传感器数据等操作。 驱动程序调用应用层API的好处是实现了驱动程序与应用程序的分离。应用层API封装了底层硬件设备的具体操作细节,使得驱动程序能够以一种统一的接口与应用程序进行交互。这样,应用程序开发者无需了解底层硬件设备的具体细节,只需调用API提供的函数即可完成相应的操作。同时,驱动程序的开发者也无需考虑具体的应用场景和应用程序的实现,只需提供对应的API接口即可。 总之,驱动程序通过调用应用层API实现了与应用程序的交互,提供了与硬件设备进行通信和控制的能力。这种方式能够简化应用程序和驱动程序的开发,提高了系统的可维护性和可扩展性。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值