标题:
[推荐]软件脱壳技术
[打印本页]
作者:
lp乌鸦
时间:
2003-10-6 21:58
标题:
[推荐]软件脱壳技术
使用工具: loader、TRW2000、superbpm、Import REConstructor v1.4.2+
这个软件同样是在汉化新世纪论坛上有朋友要的,我的水平太烂,搞了好半天才搞定了脱壳:)
脱壳过程:
一.找程序的入口点
用 fs0 大哥的 loader 载入软件主程序,几秒钟后 loader 会告诉你,程序的 OEP 是 0043835E。
二.TRW 初步脱壳
下面要在入口处脱壳,先打开 SuperBPM,选中 erase 前面的复选框,然后用 TRW 载入 adr.exe,下g 43835E,TRW 停在程序的入口处,接着下 pedump ,将内存中的程序脱出来。
三.修复导入表
打开原加壳程序,在 Import REConstructor v1.4.2+ 的 Attach to an Active Process 窗口中选取 adr.exe 进程,然后在下方的 OEP 处填入正确的入口 0001000,点 IAI AutoSearch,再点 Get Imports ,然后点 Show Invalid,在Imported Functions Found 窗口里的无效地址上点鼠标右键,选 Trace Leve11(disasm),这样 Import REConstructor 能够自动修复的项目就搞定了。
再点 show invaids,发现还剩下几个没有修复,再次在那几个没有修复的地址上点鼠标右键,选中 Plugin Tracer(Asprotect 1.2X Emul),这样这个插件能修复的项目也全部搞定了。再点 show invaids,所有的导入表项目都显示有效了,运气真好:)
现在点击 Fix Dump,选择 TRW 脱壳出来的文件 dump.exe,会在目录下生成修正了导入表的程序 dump_.exe
四.去软件校验
运行 dump_.exe,弹出一个提示,说“crypt api not found....”云云,不爽,还有校验啊:(
TRW 载入 dump_.exe,下 pmodule,来到程序领空,然后下断点 bpx messageboxa,F5 运行程序,马上被 TRW 断了下来。(如果这里不先下 pmodule,直接下断,F5,程序会被断在 BFFXXXX 这个地址上,不在程序的领空内)
0167:00434C70 6A04 PUSH BYTE +04
0167:00434C72 6AFF PUSH BYTE -01
0167:00434C74 FF151C224400 CALL `KERNEL32!GetProcAddress`
0167:00434C7A 85C0 TEST EAX,EAX // EAX 是否为1
0167:00434C7C A3DC7B4600 MOV [00467BDC],EAX
0167:00434C81 7516 JNZ 00434C99 // 不是则死,所以 JNZ => JMP
0167:00434C83 6A10 PUSH BYTE +10
0167:00434C85 68AC634400 PUSH DWORD 004463AC
0167:00434C8A 687C9A4400 PUSH DWORD 00449A7C
0167:00434C8F 50 PUSH EAX
0167:00434C90 FF1530234400 CALL `USER32!MessageBoxA` // 弹出 crypt api not found.... 的提示
0167:00434C96 33C0 XOR EAX,EAX
0167:00434C98 C3 RET // 上面的校验过程结束
0167:00434C99 B801000000 MOV EAX,01 // 跳到此处,即可跳过校验
0167:00434C9E C3 RET
所以将 0167:00434C81 的 JNZ 00434C99 改为 JMP 00434C99 即可。用 LodePE 的 FLC 功能,得 offset 34C81,用十六进制编辑工具改之 (75 -> EB)。
因为是朋友汉化需要,特别用 eXescope 编辑了一下资源,无问题。
五 破解
汗...这个我跟了半天,一点头绪都没有,倒是有跟到一个跳转,改了之后随意输入注册码都会提示注册成功,不过根本没有用-_-# 这个还是留待高手解决吧:P
欢迎光临 黑色海岸线论坛 (http://bbs.thysea.com/)
Powered by Discuz! 7.2