yunfeng 发表于 2007-12-23 08:34:32

ASProtect 2.1X之VB程序&OEP修复

【文章标题】: ASProtect 2.1X之VB程序&OEP修复
【文章作者】: wynney
【软件名称】: Klasik
【软件大小】: 979K
【下载地址】: 见附件
【加壳方式】: ASProtect 2.1X
【保护方式】: 仅代码变形+Stolen Code
【编写语言】: VB
【使用工具】: Shadow,LoadPE,ImportREC
【操作平台】: XP SP1
【软件介绍】: 国外论坛上某人我自脱的小东西。。。
【作者声明】: 凑热闹~而已^_^
--------------------------------------------------------------------------------
【详细过程】
VolX大虾的脚本已经完美无比了,佩服ing,但是,我这个人有个习惯,不喜欢用脚本,虽然很累~但是,充实^_^这篇陋文
也是按前人的思路来作~前人太多~就不列表了:)我就按我的流程写详细吧,突出点不一样~呵呵

1、突击敌后--探听虚实
第一步我们需要探听以下几点~为后面做准备呀~
   i、OD忽略除了int3和指定异常之外的所有异常,隐藏OD(我这里隐藏不隐藏好像都一样),F9,中断。搜索所有参考文本。
      找到两个85吧,双击任何一个“85”,来到代码处~


引用:
0130EBF8    68 E8F43001   push 130F4E8                        ; ASCII "85"
0130EBFD    E8 2A62FEFF   call 012F4E2C
0130EC02    A1 1C373101   mov eax,dword ptr ds:
0130EC07    8B00            mov eax,dword ptr ds:
0130EC09    E8 0A8CFFFF   call 01307818                     ;F2,Shift+F9中断下来,继续F7
0130EC0E    84C0            test al,al
0130EC10    75 0A         jnz short 0130EC1C
0130EC12    68 E8F43001   push 130F4E8                        ; ASCII "85"
   


引用:
01307818    53            push ebx                            ;来到这里,去段尾。。。
01307819    56            push esi
0130781A    57            push edi
.....
.....
.....
01307959    56            push esi
0130795A    E8 59FCFFFF   call 013075B8                        ;F4下来,接着就是F7
0130795F    0FB707          movzx eax,word ptr ds:
01307962    83C0 02         add eax,2
01307965    03F8            add edi,eax
01307967    8A1F            mov bl,byte ptr ds:
01307969    47            inc edi
0130796A    3A5E 34         cmp bl,byte ptr ds:
0130796D^ 0F85 77FFFFFF   jnz 013078EA
01307973    8BDF            mov ebx,edi
01307975    8B03            mov eax,dword ptr ds:
01307977    85C0            test eax,eax
01307979^ 0F85 0AFFFFFF   jnz 01307889
0130797F    8A0424          mov al,byte ptr ss:
01307982    83C4 0C         add esp,0C
01307985    5D            pop ebp
01307986    5F            pop edi
01307987    5E            pop esi
01307988    5B            pop ebx
01307989    C3            retn
段尾好像都长这个样子,一个CALL,两个向上的跳,一个retn(简称121)
   


引用:
013075B8    55            push ebp
013075B9    8BEC            mov ebp,esp
013075BB    81C4 F8FEFFFF   add esp,-108
013075C1    53            push ebx
....
....
....
013075F2    3BF0            cmp esi,eax
013075F4    75 5E         jnz short 01307654                   ;我们探听的内容之一,纪录下吧   
013075F6    EB 01         jmp short 013075F9                   ;我们探听的内容之二,纪录下吧
....
....
....
在013075F4下F2,Shift+F9运行中断下来
此时可以看到EAX=4F,ESI=98
好我们先不要急着按F9,下面还是进行我们探听的内容之三,Ctrl+G-->00401000-->Ctrl+B,查找FF 25-->
这样一来我们就得到探听内容之三(0040FCC0- FF25 C4114000   jmp dword ptr ds:)长得像这样的
东西-->右键数据窗口中跟随-->往上翻翻,往下翻翻,找到IAT Start(00401000)&IAT End(004014D4),纪录下来吧

接下来就按F9吧~按了一下F9之后,在数据窗口中Ctrl+G-->00401000(IAT Start),观察IAT的变化
同时眼睛还要尖锐点注意ESI的变化,ESI变化的次序98,4F,7E
按了N多下,转存窗口中的IAT一直都在变,而且都出来。。。。。哎~伤害感情~原来IAT没有加密:)
那些变化看够了没?看够了就取消断点吧,断点取消了吧?把OD异常设置换下吧~INT3打上勾~内存访问
去掉勾,F9几下来到最后一次异常,找段尾的倒数第一个CALL XXXXXXXX
   


引用:
0130FBF5    E8 1A30FDFF   call 012E2C14
0130FBFA    E8 B5D0FFFF   call 0130CCB4    ;都长这个样~F2,F9中断下来
0130FBFF    83C4 2C         add esp,2C
0130FC02    5D            pop ebp
0130FC03    5F            pop edi
0130FC04    5E            pop esi
0130FC05    5B            pop ebx
0130FC06    C3            retn
接下来不要急着F7,先Ctrl+G-->00401000-->Ctrl+B,查找FF 25,和他们在一起的会有代码变形的那些东西
(0040FCD2    E8 29031401   call 01550000)这个1550000就是我们探听的内容之四纪录下来~
   


引用:
F7进call 0130CCB4去吧~Ctrl+F9返回~这样我们在反汇编窗口下面就会发现有
0130CD44    C3            retn
   
引用:
返回到 01530211
   
不要按F7了~把01530211记住先~这便是我们要探听的内容之五了
   


引用:
在00401000段下F2,F9运行~看到这样的代码了
004103F8- FF25 D4134000   jmp dword ptr ds:                ; msvbvm60.ThunRTMain
004103FE    0000            add byte ptr ds:,al
00410400- E9 0CFE1101   jmp 01530211
00410405    9B            wait
00410406    A2 093EBF16   mov byte ptr ds:,al
0041040B    0000            add byte ptr ds:,al
恭喜恭喜,OEP被抽了~但是,VB程序抽OEP是小意思了~
   

引用:
注意看堆栈
0012FFBC   01530295返回到 01530295 来自 01590000
0012FFC0   0041744CASCII "VB5!6&*"
   


引用:
这个时候你可以随便找个VB程序看看入口~
0040116C >/$68 147C4000   push VB.00407C14                   "VB5!6&*"
00401171|.E8 F0FFFFFF   call <jmp.MSVBVM60.ThunRTMain>
00401176|.0000          add byte ptr ds:,al
00401178|.0000          add byte ptr ds:,al
VB的入口都张这样
   


引用:
那么我们很清楚了吧?
这个被抽的代码就是这样的了
push 0041744C
call 004103F8
68 4C 74 41 00 E8 EE FF FF FF
这是我们探听的内容之六
   


引用:
这里我说明下选那个地址做OEP呢?
看看这个
00410400- E9 0CFE1101   jmp 01530211
这里的01530211不正是我们Stolen Code的OEP吗?
哎~很明了了~我们就选00410400做OEP!
这是我们探听的内容之七
   

好虚实探听好了~现在来修复变形代码吧
这个的IAT根本没有加密,我们还是有必要事先走个过场熟悉下^_^

2、IATFixing(没有加密嘛~跳过~)

3、代码变形处理
这里前面有很多朋友介绍得相当多了,我还是赘述下吧~
OD忽略除了内存访问之外的所有异常,到最后一次异常~
找段尾的倒数第一个CALL XXXXXXXX

引用:
0130FBF5    E8 1A30FDFF   call 012E2C14
0130FBFA    E8 B5D0FFFF   call 0130CCB4    ;F2,F9中断下来~用内存分配插件分配个1640000,SIZE=10000
0130FBFF    83C4 2C         add esp,2C
0130FC02    5D            pop ebp
0130FC03    5F            pop edi
0130FC04    5E            pop esi
0130FC05    5B            pop ebx
0130FC06    C3            retn
   
Ctrl+B-->89,45,F0,B8,00,07,00,00

引用:
找到这里
01307188    8945 F0         mov dword ptr ss:,eax
0130718B    B8 00070000   mov eax,700
01307190    E8 B7B3FDFF   call 012E254C   ;改成jmp 1640037
   


引用:
Ctrl+G-->1640000,写上这些代码~
01640000    BA 00104000   mov edx,KLASIK.<ModuleEntryPoint>   ;写完之后一定要新建EIP,再运行~
01640005    803A E8         cmp byte ptr ds:,0E8
01640008    75 12         jnz short 0164001C
0164000A    8B42 01         mov eax,dword ptr ds:
0164000D    03C2            add eax,edx
0164000F    83C0 05         add eax,5
01640012    3D 00005501   cmp eax,1550000                     ;变形的IAT,也是上面纪录的内容
01640017    75 03         jnz short 0164001C
01640019    EB 0C         jmp short 01640027
0164001B    90            nop
0164001C    42            inc edx
0164001D    81FA 00F08200   cmp edx,82F000                      ;00401000区段后面的那个区段的起始地址
01640023^ 72 E0         jb short 01640005
01640025- EB FE         jmp short 01640025
01640027    8915 00016401   mov dword ptr ds:,edx      ;申请的地址+100
0164002D    60            pushad
0164002E    FFE2            jmp edx
01640030    90            nop
01640031    90            nop
01640032    90            nop
01640033    90            nop
01640034    90            nop
01640035    90            nop
01640036    90            nop
01640037    60            pushad
01640038    B8 00104000   mov eax,00401000                      ;IAT Start   
0164003D    90            nop
0164003E    3910            cmp dword ptr ds:,edx
01640040    75 20         jnz short 01640062
01640042    8B0D 00016401   mov ecx,dword ptr ds:      ;申请的地址+100
01640048    C701 FF250000   mov dword ptr ds:,25FF         ;JMP为25FF,CALL为15FF
0164004E    8941 02         mov dword ptr ds:,eax
01640051    61            popad
01640052    90            nop
01640053    8B15 00016401   mov edx,dword ptr ds:      ;申请的地址+100
01640059    90            nop
0164005A    90            nop
0164005B    90            nop
0164005C^ EB BE         jmp short 0164001C
0164005E    90            nop
0164005F    90            nop
01640060    90            nop
01640061    90            nop
01640062    83C0 04         add eax,4
01640065    3D D4194000   cmp eax,4014D4                        ;IAT End
0164006A^ 7E D2         jle short 0164003E
0164006C^ EB E3         jmp short 01640051

BA 00 10 40 00 80 3A E8 75 12 8B 42 01 03 C2 83 C0 05 3D 00 00 55 01 75 03 EB 0C 90 42 81 FA 00
F0 82 00 72 E0 EB FE 89 15 00 01 64 01 60 FF E2 90 90 90 90 90 90 90 60 B8 00 10 40 00 90 39 10
75 20 8B 0D 00 01 64 01 C7 01 FF 25 00 00 89 41 02 61 90 8B 15 00 01 64 01 90 90 90 EB BE 90 90
90 90 83 C0 04 3D D4 14 40 00 7E D2 EB E3

这里没什么技巧,不过一定得注意我上面标注好的位置!在你按F9之前先确认一遍~不然~嘿嘿~
   

F9运行之后~判断成功如否的一个标志就是左上角OD提示“运行”~机器卡卡卡~哈哈~

OK,此时LoadPE完全Dump~打开ImportREC,OEP填10400看看`~点“自动查找IAT”提示“在此OEP处。。。”
晕糊糊~~呵呵~不急~因为这个地方的代码被抽取了嘛`当然。。。我们填103EF~再来看看~啊。。晕糊糊~有4个无效哦
仔细看看~后面3个没用~剪掉吧~但是,在MSVBVM60.DLL里面却有一个无效~~右键反汇编查看。。。有个
// = msvbvm60.dll/00BB//DllFunctionCall,就把它改成DllFunctionCall吧~OK,此时把OEP换成10400,FixDump!

用OD打开修复后的程序~二进制粘贴68 4C 74 41 00 E8 EE FF FF FF保存下`~OK~运行正常~体积4.44M:(懒得减肥了
太累了~~

PS:如果你想使用区段填补的方法~可以以01530211做OEP,把012E0000~016B0000中所有的区段都补回去~不过等着你的
是Route Check,这个用SYSCOM斑竹的代码。。。~OK,当然你要知道怎么跟到那个地方去~很简单~自己去跟下~

--------------------------------------------------------------------------------
【经验总结】
VB程序的加壳一直都是软件作者很头痛的问题吧~呵呵~看这个程序就知道了,软柿子一个!没什么技术含量,大虾就飘过吧
~

--------------------------------------------------------------------------------

yunfeng 发表于 2007-12-23 08:35:58

这篇教程配合天草高级班视频破解第十课,没有使用脱壳脚本,而是手动脱壳,现在二进制翻录的第十课已不能下了,那位兄弟能上传一下,谢谢

[ 本帖最后由 yunfeng 于 2007-12-23 08:43 编辑 ]

soychino 发表于 2007-12-23 11:39:35

好文,学习!!!!

angelfish 发表于 2007-12-28 15:02:07

学习下……呵呵……对我有点难度

jicket 发表于 2007-12-31 12:08:23

不错啊 极品 顶/:014 /:014

magic659117852 发表于 2007-12-31 13:00:46

【文章作者】: wynney

/:good 天草就是牛X

cc7x 发表于 2008-1-8 23:03:15

嗯 ,牛X,确实是的

樊盟 发表于 2008-9-20 11:30:34

正在找,学习一下,谢谢楼主!

NONAME剑人 发表于 2008-9-22 19:15:43

bp msvbvm60.ThunRTMain可不可以?SF以前就被这么虐过……
页: [1]
查看完整版本: ASProtect 2.1X之VB程序&OEP修复