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:43 编辑 ] 好文,学习!!!! 学习下……呵呵……对我有点难度 不错啊 极品 顶/:014 /:014 【文章作者】: wynney
/:good 天草就是牛X 嗯 ,牛X,确实是的 正在找,学习一下,谢谢楼主! bp msvbvm60.ThunRTMain可不可以?SF以前就被这么虐过……
页:
[1]