|

编号为1的结果显示是从偏移0000开始替换的,在我的机器上这个结果不用考虑,因为卡巴斯基软件对于没有PE头的文件是不进行特征码检测的,文件1中恰好是PE头被替换了,自然就不会被删除。(据说别的杀毒软件,比如Norton,不管有没有PE文件头都会进行特征码检测,具体情况要具体分析。)因此初步确定特征码在编号2的文件所表示的范围内,既0x2DC2到0x44A3之间的0x16E1个字节的范围内。
" X) g+ J8 o/ J' H2 h4 ~ G D重新设置参数为自动,读入原文件,在“用户输入区”直接输入起始位置2DC2和检测大小16E1,不填充0,然后点击添加区段,确定后进入操作窗口。打开监测,单击GO,开始自动检测,操作方法和检测winshell时一样。又经过一番对鼠标右键的折磨,终于得出了结果:' P: K5 S! `* G% F& @9 I2 d& ~2 Y
-------------定位结果------------
* _6 Q& }( i: \1 z! {# w/ w 序号 起始偏移 大小 结束偏移
+ q* d) L( S( z6 t4 K4 g8 ^ ] 0001 000031C6 00000016 000031DC % |, u9 Q- N6 \1 U/ |9 }9 n
0002 00003A16 0000002C 00003A42
$ D; f7 M+ ?( Y1 l5 G4 b% e 0003 00003A44 0000002C 00003A70 ( I' i3 p+ ~* H; h k
0004 00003A71 0000002C 00003A9D
! a0 t, D) H9 z6 W. s# O9 \ 0005 00003AA0 0000002C 00003ACC
1 F6 X/ g1 V- J0 ]' A3 c6 I 0006 00003ACD 0000002C 00003AF9
+ s- M% S0 F! h. }1 n( Z, E 哇,有6处耶!老规矩,柿子要挑软的捏,我们先来查看范围最小的0001项。OllyDbg打开原文件,找到0x004031C6处,看看是些什么。怎么回事?不是汇编指令啊!除了0就是几个毫无意义的数据。( F3 F3 s6 `3 H0 ~1 E# b; U% z: x
004031C6 00 db 00+ C& [- W& s- V
…
5 G- Z1 G/ N5 t* C004031D4 BA db BA
) @ A6 @8 d$ j* y! R004031D5 DA db DA
* Q3 z1 P2 A* f" _- B- x004031D6 C9 db C9
# c% S4 T# \7 p* L* `: l004031D7 E7 db E7
! |; l" J. \) g6 ~$ G/ }004031D8 BB db BB
w: h0 C2 f) H( s7 ^% A2 y( ]004031D9 E1 db E1
4 G! }" k% q) e2 r: z" c! m& w" B004031DA 00 db 00
/ t5 I# }: n `- [/ F…% l' J8 W+ F4 ~, V* n
不是汇编指令,那可不可能是字符串呢?我们在命令行里打“dd 004031d4”,既显示0x004031d4处的内容,然后将数据窗口的显示方式改为“文本ASCII(32)”,随即左下角小窗口中显示出“黑社会”三个字,而且有三处。[见图7]原来“BADAC9E7BBE1”是这三个汉字的ASCII代码。难道杀毒软件就靠文件中的“黑社会”去识别黑社会? 
未了证明我们的想法,我们用32位编辑工具UltraEdit打开原文件,搜索“黑社会”三个字,一共找到了7处。干脆,一不做二不休,我们将7处“黑社 会”全部替换为“白晶晶”。[见图8] . _/ n8 k. M6 @
保存一下,再用杀毒软件检测。我靠,果然认不出来了!黑社会2.0的特征码就这样被我们搞定了,真是得来全不费工夫啊,竟然是直接用汉字作为特征码!运行一下修改过的文件,挺好使,就是“关于”窗口上的标题从“黑社会”变成“白晶晶”了,呵呵! ( a% \* c" G9 R; c7 _4 A
六、 关于多处特征码的一点补充
" z) I# j3 G x6 ^1 N3 H' j前面两个实战中,我们虽然定位出了多处特征码,但只修改其中一处就可以了,这种情况不一定适用于所有的程序。根据笔者经验,特征码可能有主副之分。主特征码被修改,则无论副特征码是否存在,文件均可以逃过追杀;但如果只修改副特征码,而不修改主特征码,则文件始终会被杀毒软件辩认出来,只不过识别出的版本有所差别。所以,我们修改的目标重点是文件中的主要特征码。( M/ N6 H5 w F3 S9 x- H4 f, r. k
七、 结语, x9 v% [$ l- N @- E6 ^7 e
差不多了,我们来总结一下吧!: e& [7 t0 u9 ]# ]1 M3 N
用CCL定位特征码时,手动替换和自动替换应该互补使用,没有一个方法是全能的。通常为用手动确定大范围,用自动精确定位小范围。定位成功后,看特征码的类型。如果是汇编指令,用“指令顺序调换法”或“万能跳转法”进行修改;如果是字符串等,在不影响原程序运行的情况下,替换掉既可。
7 F! f4 q' J0 Z8 d' G操作方法也很重要,操作过程中注意和杀毒软件的配合,多试几次,掌握不同杀毒软件的特点,合理设置等待时间和最小定位精度等参数。更重要的是,确保自动检测过程中,杀毒软件对生成文件进行了检测,适当加上点“刺激”(比如我的鼠标右键刺激大法)。+ a6 I0 }6 @5 G$ X/ l
讲到这儿,相信你应该知道怎样打造自己的无敌黑器了吧! |