这个dll_CopycatAndHide 的masm源代码

本文提供了一段MASM汇编代码和C++代码,用于实现DLL的复制和隐藏功能。通过复制DLL到新的内存区域并修改原始入口点,达到断开链表和隐藏的效果。在汇编代码中,主要使用了VirtualAlloc、VirtualProtect和RtlZeroMemory等API进行内存操作。C++版的实现也类似,使用了LoadLibrary、VirtualAlloc和FreeLibrary等函数。
摘要由CSDN通过智能技术生成


;2015/1/7

;作用:简单的断去链表的方法 实用  也可以达到隐藏的效果 成功返回1失败返回0 

;失败原因:例如内存分配不成功等等 一般是在过程中出错

;esp+8传入 DLL的句柄

dll_CopycatAndHide proc   dllhandle:dword 

LOCAL SizeOfImage,lpBackMem,oldprotect,AddressOfEntryPoint,g_lpNewImage

pushad

mov eax,dword ptr [dllhandle]

mov eax,dword ptr [eax+IMAGE_DOS_HEADER.e_lfanew]

add eax,dword ptr [dllhandle]

lea eax,dword ptr [eax+IMAGE_NT_HEADERS.OptionalHeader]

mov ebx,dword ptr [eax+IMAGE_OPTIONAL_HEADER.AddressOfEntryPoint];入口点

mov dword ptr [AddressOfEntryPoint],ebx;保存入口点

mov eax,dword ptr [eax+IMAGE_OPTIONAL_HEADER.SizeOfImage]

mov dword ptr [SizeOfImage],eax;保存SizeOfImage

invoke VirtualAlloc,0,eax,MEM_COMMIT or MEM_RESERVE ,PAGE_EXECUTE_READWRITE

mov dword ptr [lpBackMem],eax;保存内存开始地址

test eax,eax

je retf1;查看是否申请内存成功 失败就返回

invoke VirtualPro

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值