EXE程序的自删除实现

所属分类: 软件教程 / 其他工具 阅读数: 1091
收藏 0 赞 0 分享

程序的自删除已经不是什么新鲜的话题了,它广泛运用于木马、病毒中。试想想,当你的程序还在运行中(通常是完成了驻留、感染模块),它就自动地把自己从磁盘中删掉,这样一来,就做到了神不知鬼不觉,呵呵,是不是很cool呢?

自删除(Self Deleting)最早的方法是由 Gary Nebbett 大虾写的,太经典了,不能不提。程序如下:

#include "windows.h"

int main(int argc, char *argv[])
{
char buf[MAX_PATH];
HMODULE module;

module = GetModuleHandle(0);
GetModuleFileName(module, buf, MAX_PATH);
CloseHandle((HANDLE)4);

__asm 
{
lea eax, buf
push 0
push 0
push eax
push ExitProcess
push module
push DeleteFile
push UnmapViewOfFile
ret
}

return 0;
}

试试编译它,运行。怎么样?从你的眼皮底下消失了吧?是不是很神奇?

Gary Nebbett 钻了系统的一个漏洞,他的程序是关闭了 exe 文件的 IMAGE(硬编码为4),然后用 UnmapViewOfFile 解除了 exe 文件在内存中的映象,接着通过堆栈传递当前程序的 Handle 给 DeleteFile() ,实现了程序的自删除。

Gary Nebbett 果然不愧为 WIN 系统下顶尖的底层高手。那么是否还有其他的方法实现程序的自删除呢?答案是肯定的。

在 Win9x/ME 下,还可以利用 WININIT.INI 的一些特性。在 WININIT.INI 文件里面有一个节 [Rename] ,只要在里面写入要 “Nul=要删除的文件”,那么下次系统重新启动的时候,该文件就会被自动删除了。以下是一个例子:

[Rename]
NUL=c:\SelfDelete.exe

利用这个特性,我们就可以在程序中对这个 ini 文件进行操作。值得注意的是,当需要自删除的文件多于一个的时候,就不能使用 WritePrivateProfileString 来实现,因为这个 API 会阻止多于一个“NUL=”这样的入口在同一个节里面出现,所以最好还是自己手动实现。

第三种方法是利用批处理文件。先让我们做一个试验:

创建一个 a.bat ,给它写入以下内容:

del %0.bat

现在运行它吧,屏幕一闪而过,最后留下一串字符:“The batch file cannot be found”。这时候它已经从你的硬盘中消失了。

这说明,批处理文件是可以删除自己的,于是我们可以把这个小技巧运用在自己的程序当中:

:Repeat
del "C:\MYDIR\SelfDelete.exe"
if exist "SelfDelete.exe" goto Repeat
rmdir "C:\MYDIR"
del "\DelUS.bat"

它会重复不断地搜索是否有 SelfDelete.exe 这个文件,直到删除了它为止;当删除完毕后,这个批处理文件就会把自己删除。
(注:本方法可以支持所有的 Windows 版本,即 Win9x/Me/NT/2000/XP)

用批处理文件的方法有一个缺陷,就是会突然弹出一个 DOS 窗,冷不防的吓人一跳,不过据我所知这是目前唯一可以在 WinXP 下起作用的方法。当然,最理想的方法是用 Gary Nebbett 的那种,不过它的缺陷是没法在 WinXP 下起作用。

更多精彩内容其他人还在看

UG钣金模块怎么制作合叶模型?

UG钣金模块怎么制作合叶模型?UG中绘制零件很方便,该怎么绘制合叶模型呢?下面我们就来看看UG使用钣金模块制作合叶模型的详细图文教程,需要的朋友可以参考下
收藏 0 赞 0 分享

UG模型中的文字无法拉伸该怎么办?

UG模型中的文字无法拉伸该怎么办?在拉伸模具的时候,发现模型中的文字没有跟着模型变化,拉伸对文字不起作用,该怎么办呢?下面我们就来看看这个问题的解决办法,需要的朋友可以参考下
收藏 0 赞 0 分享

Axure RP 8怎么完成一个登录界面并链接对应功能?

Axure RP 8怎么完成一个登录界面并链接对应功能?我们在做网页的时候,一般都会在Axure中先做原型并实现相应功能,今天我们就来看看Axure RP 8制作登录并链接功能的教程
收藏 0 赞 0 分享

ug怎么装配台虎钳? 虎钳ug建模到装配的教程

ug怎么装配台虎钳?在设计虎钳的时候想看看虎钳部件设计是否合适,以及检查配合部分的干涉问题,该怎么办呢?下面我们就来看看ug建模到装配的教程,需要的朋友可以参考下
收藏 0 赞 0 分享

ansys有限元怎么导入solidworks绘制好的模型?

ansys有限元怎么导入solidworks绘制好的模型?ansys需要使用一些模型软件模型,在solidworks绘制好以后该怎么导入到ansys中呢?下面我们就来看看详细的教程
收藏 0 赞 0 分享

谷歌卫星地图怎么添加标注?

谷歌卫星地图怎么添加标注?想要在地图上标注文字,该怎么标注呢?下面我们就来看看谷歌卫星地图添加标注的详细教程,下面我们就来看看这个问题的解决办法,需要的朋友可以参考下
收藏 0 赞 0 分享

ug中怎么绘制鼠标外壳模型?

ug中怎么绘制鼠标外壳模型?ug可以制作零件模型,今天我们就来看看使用ug绘制鼠标的实例教程,绘制教程很简单,图文很详细,需要的朋友可以参考下
收藏 0 赞 0 分享

Acrobat DC Pro怎么注册 Acrobat DC Pro注册详细图文教程

acrobat pro dc是目前Adobe公司最新发布的全新一代PDF制作软件,很多朋友不知道Acrobat DC Pro怎么注册,今天小编就为大家带来Acrobat DC Pro注册教程,一起看看吧
收藏 0 赞 0 分享

MathType编辑积分符号该怎么编辑?

MathType编辑积分符号该怎么编辑?MathType中可以编辑公式,word经常nag使用它 编辑公式,但是MathType中该怎么输入积分符号呢?下面我们就来看看这个问题的解决办法,需要的朋友可以参考下
收藏 0 赞 0 分享

MathType中怎么编辑箭头上下都添加文字?

MathType中怎么编辑箭头上下都添加文字?MathType中编辑公式很方便,如果想编辑类似于往返的符号,就是做大巴经常能看到双向箭头上下都有往返的路线文字,该怎么编辑呢?请看下文详细介绍
收藏 0 赞 0 分享
查看更多