Acpr1.41-2.0_unpacker全自动脱壳脚本
此脚本是在前人基础上改进而成,自动修复ITA和DUMP。
SORRY!这个脚本最初原作者是zpunpack,我只是在试验脚本编写过程中发现VolX大侠写的
Aspr2.XX_unpacker_v1.0SC.osc 脚本能自动DUMP文件,于是就进去挖掘了一下,发现关键
点,立即查看了hnhuqiong大侠的OllyScript中文说明.txt
=========================================================
DPE 文件名, 入口
----------------
<Dump Process with Entry point>
提取执行模块到指定文件中。
“入口”用来设定入口地址。
这个命令用来抓取文件,还是比较好用的,因为直接利用了OD强大的内存管理功能.
例:
dpe "c:\test.exe", eip //入口为当前地址,保存为C盘下test.exe
=========================================================
受启发后就实验了这句:dpe "\\已脱壳未修复IAT.exe", eip
发现脚本自动帮我们DUMP下来了,所以就索性拿Acprotect这个脚本改造了一下,并无技术含量
脚本编写我只是入门而已,还要向前辈们多学习才行。
=====================================================================
刚才经过skylly大侠的指点,修正了一下,如果遇到出错,请尝试重新运行一下
脚本!
=====================================================================
/*
Script written by ~icy~学习班
Script : Acpr1.41-2.0_unpacker全自动脱壳
日期 : 2007-03-26
调试环境 : OllyDbg 1.1, ODBGScript 1.51, Winxp Win2003
调试选项 : 设置 OllyDbg 忽略所有异常选项
工具 : OllyDbg, ODBGScript 1.51, Import Reconstructor.
*/
//support ACprotect1.41-2.0 UltraProtect 1.x
var eipaddr1
var esiadd
var ebxadd
var cbase
var csize
var imgbase
var iatrva
var add1
GMI eip, MODULEBASE
cmp $RESULT,0
je lblabort
mov imgbase,$RESULT
gmi eip,CODEBASE //获得代码基地
cmp $RESULT,0
je lblabort
mov cbase,$RESULT
mov cbase,$RESULT
gmemi cbase,MEMORYsize
cmp $RESULT,0
je lblabort
mov csize,$RESULT
gpa "GetModuleHandleA","kernel32.dll"
cmp $RESULT,0
je lblabort
mov add1,$RESULT
bprm add1,ff
esto
bpmc
rtu
findop eip,#F3AA# //查找指定内容
cmp $RESULT,0
je lblabort
repl $RESULT,#F3AA#,#9090#,2
bp $RESULT
run
bc $RESULT
sto
sto
sto
bprm add1,ff
esto
bpmc
rtu
mov eipaddr1,eip
mov eipaddr1,eipaddr1-30
mov esiadd,esi+0c
mov ebxadd,ebx-imgbase
mov [esiadd],ebxadd
mov iatrva,esi-imgbase
findop eipaddr1,#83660c00# //地址中查找:and dword ptr ds:[esi+C],0
cmp $RESULT,0
je lblabort
repl $RESULT,#83660C00#,#90909090#,4
find eipaddr1,#2BC08803# //内存中查找:sub eax,eax mov byte ptr ds:[ebx]
cmp $RESULT,0
je lblabort
repl $RESULT,#2BC08803#,#90909090#,4
find eipaddr1,#2BC08803#
cmp $RESULT,0
je lblabort
repl $RESULT,#2BC08803#,#90909090#,4
find eipaddr1,#80BD16564100007457# //魔法跳
je lblabort
repl $RESULT,#80BD16564100007457#,#80BD1656410000eb57#,9 //jmp
find eipaddr1,#8DBD??????0033C0#
cmp $RESULT,0
je lblabort
bp $RESULT
esto
bc $RESULT
bpmc
bprm cbase,csize
esto
cmt eip,"传说中的光明之颠~OEP~"
dpe "\\已脱壳未修复IAT.exe", eip
eval "程序已脱壳请直接用ImportREC修复IAT"
msg $RESULT
ret
lblabort:
msg "脚本失败!"
ret
[招生]科锐逆向工程师培训(2024年11月15日实地,远程教学同时开班, 第51期)