我爱Aspx >> VC.Net >> 病毒及流氓软件自我复制的简单实现(C#)最近朋友的电脑中了病毒,让我跑了三次,费了九牛二虎之力,几种杀毒软件还是没有能把病毒全清除掉,最后没有办法,只能把资料复制出来,把硬盘重新分区了再装系统,装上了可以免费使用的AntiVir,于是乎世界终于清静。
不仅因为Windows系统的脆弱,而且因为病毒无休止的自我复制和满硬盘的藏匿,使得我们脆弱的神经不堪重负,面对千疮百孔,有着莫名其妙而又千奇百怪的名字文件夹和文件的系统,相信大多数人都会选择重装系统。病毒和流氓软件总是让人气愤!那么,计算机程序怎么实现自我复制呢?其实这非常的简单。下面我将用C#简单的实现一个能够自我复制的小小的恶意程序。
程序要实现下面几个功能。
第一,运行时不出现运行界面,当然,在任务管理器里,还是可以看到进程的,道行再深的病毒也不可能无迹可寻。
第二,程序在运行目录下自我复制n份。
第三,采用递归复制的方法,即第一个程序生成第二个程序,第二个程序生成第三个程序,以此类推。
源代码很简单,下面来分析一下:
| 35 // 不在任务栏显示36 this.ShowInTaskbar = false;37 // 窗体透明38 this.Opacity = 0; |
System.Windows.Forms.Form类封装了一般的Windows窗口程序大部分特性,极大的简化窗口界面的设计过程,上面这两个属性用于隐藏我们的程序的运行状态,第一个ShowInTaskbar属性,设置为否时,程序就不会在状态栏上面显示。第二个Opacity属性,表示窗口的不透明度,取值在0到100之间。0%的不透明度也就是100%透明了。这样,在程序运行时,你就看不见窗体了。
| 44 // 默认复制次数45 const int TOTAL = 100;46 int _count = TOTAL;47 // 正在运行的程序路径和文件名48 string _file = Application.ExecutablePath;49 // 正在运行的程序路径50 string _path = Application.StartupPath;51 // 正在运行的程序文件名 52 string _name = _file.Replace(string.Format("{0}\\", _path), string.Empty).ToLower();53 try54 {55 _count = int.Parse(_name.Replace(".exe", string.Empty));56 _count--;57 }58 catch59 {60 }61 finally62 {63 }64 // 目标文件65 string _target = string.Format("{0}\\{1}.exe", _path, _count.ToString("000")); |
用C#和WMI获取逻辑驱动器详细信息[03-16]
用Visual C#开发简单的复合控件[03-16]
Visual C# 2.0匿名方法揭密[03-16]
深入理解C# 3.0的五项主要改进[03-16]
病毒及流氓软件自我复制的简单实..[03-16]
在C#中建立复杂的、灵活的SQL查询..[03-16]
用C#和WMI获取逻辑驱动器详细信息[03-16]
Visual C# 2.0匿名方法揭密[03-16]
用Visual C#开发简单的复合控件[03-16]
深入理解C# 3.0的五项主要改进[03-16]
ASP.NET1.0/2.0里用DIV层元素弹出..[03-16]
扩展ASP.NET 2.0内置GridView控件..[03-16]
ASP.NET中上传文件到数据库[03-16]
用ASP.NET2.0在数据库中存储二进..[03-16]
ASP.NET2.0的multiview和wizard控..[03-16]
ASP.NET 2.0高级数据处理之数据绑..[03-16]
ASP.NET中利用VWD操作数据库[03-16]
在ASP.NET 2.0中使用样式、主题和..[03-16]
在ASP.NET 2.0中建立站点导航层次[03-16]
三层Web体系结构里的两种数据绑定..[03-16]