摘自陈立新《计算机病毒防治百事通》清华大学出版社 3w p@OF_
计算机病毒比较法诊断的原理 pnx^a}|px
比较法是用原始的或正常的与被检测的进行比较。比较法包括长度比较法、内容比较法、内存比较法、中断比 zx:;0Z:S6>
较法等。比较时可以靠打印的代码清单(比如DEBUG的口命令输出格式)进行比较,或用程序来进行比较(如DOS的 6+ptL-Zt<
DISKCOMP、COMP或PCTOOLS等其他软件)。这种比较法不需要专用的查病毒程序,只要用常规DOS软件和 PCTOOLS等 c'VCCXe
工具软件就可以进行。而且用这种比较法还可以发现那些尚不能被现有的查病毒程序发现的计算机病毒。因为病毒 $>_`.*I/
传播得很快,新病毒层出不穷,由于目前还没有做出通用的能查出一切病毒,或通过代码分析,可以判定某个程序 BT0;I
中是否含有病毒的查毒程序,发现新病毒就只有靠比较法和分析法,有时必须结合这两者来一同工作。 Uj 4HVd
1.长度比较法及内容比较法 1uKIO{d@
病毒感染系统或文件,必然引起系统或文件的变化,既包括长度的变化,又包括内容的变化。因此,将无毒的 ,+h<qBsV@
系统或文件与被检测的系统或文件的长度和内容进行比较,即可发现病毒。长度比较法和内容比较法就是从长度和 >jTiYJI_M
内容两方面进行比较而得名。 rc>}3?o
以长度或内容是否变化做为检测病毒的依据,在许多场合是有效的。但是,众所周知,现在还没有一种方法可 FcZ)^RQ4G
以检测所有的病毒。长度比较法和内容比较法有其局限性,只检查可疑系统或文件的长度和内容是不充分的。因为: reYIF*
(1)长度和内容的变化可能是合法的。有些普通的命令可以引起长度和内容变化。 hMS:t(N{
(2)某些病毒感染文件时,宿主文件长度可保持不变。 !@P{s'<:
上述情况下,长度比较法和内容比较法不能区别程序的正常变化和病毒攻击引起的变化,不能识别保持宿主程 FxK!h.C.
序长度不变的病毒,无法判定为何种病毒。实践告诉人们,只靠检测长度或内容是不充分的,将长度比较法、内容 'ta&qp
比较法做为检测病毒的手段之一,与其他方法配合使用,效果更好。 b W/T}FND
2.内存比较法 7 u Q +]d
这是一种对内存驻留病毒进行检测的方法。由于病毒驻留于内存,必须在内存中申请一定的空间,并对该空间 Syl 9j]
进行占用、保护。因此,通过对内存的检测,观察其空间变化,与正常系统内存的占用和空间进行比较,可以判定 |=VWE>g
是否,有病毒驻留其间。但无法判定为何种病毒。此法对于那些隐蔽型病毒无效。 Df2$2VU
3.中断比较法 ^e_uprZWm
病毒为实现其隐蔽和传染破坏之目的,常采用“截留盗用”技术,更改、接管中断向量,让系统中断向量转向 JS\]|~Gd
执行病毒控制部分。因此,将正常系统的中断向量与有毒系统的中断向量进行比较,可以发现是否有病毒修改和盗 ,+OVRc
用中断向量。 wK fq'W{
由于高版本的DOS系统在DOS引导之后重新管理一部分BIOS中断服务程序,即将原中断向量保存起来,这时;引 xqlnHf<G
导型病毒所修改的中断向量也同时被保存起来,因而从中断向量中可能观察不到引导型病毒对中断向量的修改。与 ]xb2W~
PCTOOLS一同提供的MI是一个非常有用的检测工具,它不仅能够显示系统内存大小、内存分配状况, 而且能够显示 e~># M$
出哪个驻留程序占用哪些内存空间、接管哪些中断向量。用MI软件可检测出文件型病毒常驻内存及更改部分中断向 r+#g
量的信息。 ]Y->EME:W
使用比较法能发现异常,如文件的长度有变化,或虽然文件长度未发生变化,但文件内的程序代码发生了变化。 :TKx>~`
对硬盘主引导区或对DOS的引导扇区做检查,比较法能发现其中的程序代码是否发生了变化。由于要进行比较, 保 XrMw$_0)
留好原始备份是非常重要的,制作备份时必须在元计算机病毒的环境里进行,制作好的备份必须妥善保管,写好标 ';.y`{/
签,贴写好保护签。 }c=Y<Cdh
比较法的好处是简单、方便,不需专用软件。缺点是无法确认病毒的种类名称。另外,造成被检测程序与原始 \0;w7tdo
备份之间差别的原因尚需进一步验证,以查明是由于计算机病毒造成的,或是由于DOS数据被偶然原因, 如突然停 /?Y4C)G
电、程序失控、恶意程序等破坏的。这些要用到下面介绍的分析法,查看变化部分代码的性质,以此来确证是否存 w&es N$2
在病毒。另外,当找不到原始备份时,用比较法就不能马上得到结论。从这里可以看到制作和保留原始主引导扇区 Mkt_pr
和其他数据备份的重要性。 %M8Q6
6kR3[]:16v
计算机病毒校验和法诊断的原理 o,J8n;"l
将正常文件的内容,计算其校验和,将该校验和写入文件中或写入别的文件中保存。在文件使用过程中,定期 V^n=@CZT9C
地或每次使用文件前,检查文件现在内容算出的校验和与原来保存的校验和是否一致,因而可以发现文件是否感染, %)dp
a
这种方法叫校验和法,它既可发现已知病毒又可发现未知病毒。 x+'Ea.^
这种方法既能发现已知病毒,也能发现未知病毒,但是,它不能识别病毒种类,不能报出病毒名称。由于病毒 kDQE*o
感染井非文件内容改变的唯一的排他性原因,文件内容的改变有可能是正常程序引起的,所以校验和法常常误报警, !,b&e
而且此法也会影响文件的运行速度。 MZX@Gi<S[
病毒感染的确会引起文件内容变化,但是校验和法对文件内容的变化太敏感,又不能区分正常程序引起的变动, C~.\2D`zy
而频繁报警。用监视文件的校验和来检测病毒,不是最好的方法。这种方法当遇到软件版本更新、变更口令以及修 cR55,DR,#W
改运行参数时都会误报警。 xi,fm
校验和法对隐蔽性病毒无效。隐蔽性病毒进驻内存后,会自动剥去染毒程序中的病毒代码,使校验和法受骗, 5BLBcw\;
对一个有毒文件算出正常校验和。 2p 7;v7)y
校验和法的优点是:方法简单、能发现未知病毒、被查文件的细微变化也能发现。其缺点是:必须预先记录正 f`-vnh^+
常态的校验和、会误报警、不能识别病毒名称、不能对付隐蔽性病毒。 e iH&<AH
计算机病毒扫描法诊断的原理 '< >Q20
扫描法是用每一种病毒体含有的特定字符串对被检测的对象进行扫描。如果在被检测对象内部发现了某一种特 I'n}6D.M
定字符串,就表明发现了该字符串所代表的病毒。国外管这种按搜索法工作的病毒扫描软件叫SCANNER。 扫描法包 9]G~i`QQ
括特征代码扫描法、特征字扫描法。 vGJw/ij'X
1.特征代码扫描法 vt(}8C+
病毒扫描软件由两部分组成:一部分是病毒代码库,含有经过特别选定的各种计算机病毒的代码串;另一部分 XS&;8 PO
是利用该代码库进行扫描的扫描程序。病毒扫描程序能识别的计算机病毒的数目完全取决于病毒代码库内所含病毒 9MQwc
的种类有多少。显而易见,库中病毒代码种类越多,扫描程序能认出的病毒就越多。 |KPNl\%ID
病毒代码串的选择是非常重要的。选择代码串的规则是: /Gb)BJk!
(1)短小的病毒只有一百多个字节,病毒代码长的有上10KB字节的。 如果随意从病毒体内选一段作为代表该 Ho&f[T(
病毒的特征代码串,可能在不同的环境中,该特征串并不真正具有代表性,不能用于将该串所对应的病毒检查出来。 aDLlL?r3
选这种串做为病毒代码库的特征串就是不合适的。 j2:9ahW
(2)代码串不应含有病毒的数据区,数据区是会经常变化的。 ?wIEXKI
(3)在保持唯一性的前提下,应尽量使特征代码长度短些,以减少时间和空间开销。 QJx<1#
(4)代码串一定要在仔细分析了程序之后才能选出最具代表性的, 足以将该病毒区别于其他病毒和该病毒的 fcohYo5mh
其他变种的代码串。 KNP^k$=)3c
选定好的特征代码串是很不容易的,是病毒扫描程序的精华所在。一般情况下,代码串是连续的若干个字节组 W_/$H_04+
成的串,但是有些扫描软件采用的是可变长串,即在串中包含有一个到几个“模糊”字节。扫描软件遇到这种串时, hQL@q7tUr
只要除“模糊”字节之外的字串都能完好匹配,则也能判别出病毒。 例如给定特征串:“E9 7C 00 10 ? 37 CB” YF;2jl Nm
则“E9 7C 00 10 27 37 CB”和“E9 7C 00 10 9C 37 CB”都能被识别出来,又例如: 4@ny%_/
“E9 7C 37 CB”可以匹配“E9 7C 00 37 CB”,“E9 7C 00 11 37 CB”和“E9 7C 00 11 22 37 CB”。 但不 J=O_nup6C
匹配“E9 7C 00 11 22 33 44 37 CB”,因为7C和37之间的子串已超过4个字节。 `tKs|GQf
(5)特征串必须能将病毒与正常的非病毒程序区分开。不然将非病毒程序当成病毒报告给用户, 是假警报, ^foCcO
这种“狼来了”的假警报大多了,就会使用户放松警惕,等真的病毒一来,破坏就严重了;再就是若将这假警报送 fv*
$=m
给清病毒程序,会将好程序给“杀死”了。 Pum&