-
-
[原创]给ACDSee2.44绿色版来个添油加醋diy
-
发表于:
2011-5-19 23:52
10575
-
[原创]给ACDSee2.44绿色版来个添油加醋diy
ACD是个很好的东西,我一直保留着很经典的一个版本,版本号是2.44绿色版,文件小,速度也快。
一直用着,发现有个缺点,设置的修改没法保存,打开一些比屏幕宽或屏幕高的文件时,需要手动按Ctrl+-才能自适应大小。
好吧,来PEdiy一下。用OD加载发现加壳了,手动脱壳程序无法正常运行,可能是没脱好。那就不脱壳,直接写汇编吧。
思路:
1.为exe添加新的可执行可写数据段,用来存放新的汇编代码与相关数据。
2.修改exe的AddressOfEntryPoint到新添加的数据段。
3.程序思路:先抓取需要的函数,然后创建一个枚举窗口的线程,等待程序的主窗口加载完成后向窗口发送自适应大小的命令。
4.发送的WM_COMMAND是0x4F5E是跟踪程序时找到的,过程就不写了。
汇编代码在其它汇编工具里写好,编译成EXE文件,然后将主要的执行代码写到exe中新添加的数据段中。写汇编时,需要注意的就是相对地址的处理。
为了汇编看上去好看点,可以适当的用宏处理一下。
write by ohuangkeo @ 2011-05-19 23:18:36 [原地址]
===============
以下是汇编代码:
===============
.586
.model flat, stdcall
option casemap :none
include windows.inc
include user32.inc
include kernel32.inc
includelib user32.lib
includelib kernel32.lib
;计算基地址
base MACRO
call @F
@@:
pop ebp
sub ebp, @B
add ebp, MYDATA
ENDM
;push变量
myPush MACRO b, a
lea ecx, [b+(a-MYDATA)]
push ecx
ENDM
;call变量
callMy MACRO b, a
lea ecx, [b+(a-MYDATA)]
call DWORD ptr [ecx]
ENDM
;call变量
myCall MACRO b, a
mov ecx, [b+(a-MYDATA)]
call DWORD ptr [ecx]
ENDM
;保存变量
mySave MACRO b, a, d
lea ecx, [b+(a-MYDATA)]
mov DWORD ptr [ecx], d
ENDM
.CODE
START:
jmp @F
MYDATA:
_GetModuleHandle dd 56AF60h ;绝对调用地址
_GetProcAddress dd 56AF5Ch ;绝对调用地址
_kernel db "Kernel32",00
_kernel_ dd ?
_CreateThread db "CreateThread",00
_CreateThread_ dd ?
_ThreadID_ dd ?
_CloseHandle db "CloseHandle",00
_CloseHandle_ dd ?
_Sleep db "Sleep",00
_Sleep_ dd ?
_GetCurrentProcessId db "GetCurrentProcessId",00
_GetCurrentProcessId_ dd ?
_user32 db "User32",00
_user32_ dd ?
_PostMessageA db "PostMessageA",00
_PostMessageA_ dd ?
_MessageBoxA db "MessageBoxA",00
_MessageBoxA_ dd ?
_EnumWindows db "EnumWindows",00
_EnumWindows_ dd ?
_GetWindowThreadProcessId db "GetWindowThreadProcessId",00
_GetWindowThreadProcessId_ dd ?
_getProcessId dd ? ;用于保存枚举出的窗口进程ID
@@:
pushad
base
myPush ebp, _kernel ;push "Kernel32"
myCall ebp, _GetModuleHandle ;call GetModuleHandle
mySave ebp, _kernel_, eax ;mov _kernel_
mov ebx, eax
myPush ebp, _CreateThread ;push "CreateThread"
push ebx
myCall ebp, _GetProcAddress ;call GetProcAddress
mySave ebp, _CreateThread_, eax ;mov _CreateThread_
myPush ebp, _CloseHandle ;push "CloseHandle"
push ebx
myCall ebp, _GetProcAddress ;call GetProcAddress
mySave ebp, _CloseHandle_, eax ;mov _CloseHandle_
myPush ebp, _Sleep ;push "Sleep"
push ebx
myCall ebp, _GetProcAddress ;call GetProcAddress
mySave ebp, _Sleep_, eax ;mov _Sleep_
myPush ebp, _GetCurrentProcessId ;push "GetCurrentProcessId"
push ebx
myCall ebp, _GetProcAddress ;call GetProcAddress
mySave ebp, _GetCurrentProcessId_, eax ;mov _GetCurrentProcessId_
myPush ebp, _user32 ;push "User32"
myCall ebp, _GetModuleHandle ;call GetModuleHandle
mySave ebp, _user32_, eax ;mov _user32_
mov ebx, eax
myPush ebp, _PostMessageA ;push "PostMessageA"
push ebx
myCall ebp, _GetProcAddress ;call GetProcAddress
mySave ebp, _PostMessageA_, eax ;mov _PostMessageA_
myPush ebp, _MessageBoxA ;push "MessageBoxA"
push ebx
myCall ebp, _GetProcAddress ;call GetProcAddress
mySave ebp, _MessageBoxA_, eax ;mov _MessageBoxA_
myPush ebp, _EnumWindows ;push "EnumWindows"
push ebx
myCall ebp, _GetProcAddress ;call GetProcAddress
mySave ebp, _EnumWindows_, eax ;mov _EnumWindows_
myPush ebp, _GetWindowThreadProcessId ;push "GetWindowThreadProcessId"
push ebx
myCall ebp, _GetProcAddress ;call GetProcAddress
mySave ebp, _GetWindowThreadProcessId_, eax ;mov _GetWindowThreadProcessId_
myPush ebp, _ThreadID_
push 0
myPush ebp, thread
push 0
push 0
callMy ebp, _CreateThread_
popad
mov eax, 0056A001h
jmp eax
thread: ;查找窗口的线程
pushad
base
@@:
push 100
callMy ebp, _Sleep_
push 0
myPush ebp, enum
callMy ebp, _EnumWindows_
test eax, eax
jne @B
popad
ret
enum: ;枚举查找窗口
pushad
base
push ebp
mov ebp, esp
mov ebx, DWORD ptr [ebp+28h]
pop ebp
myPush ebp, _getProcessId
push ebx
callMy ebp, _GetWindowThreadProcessId_
lea ecx, [ebp+(_getProcessId-MYDATA)]
mov ebx, DWORD ptr [ecx]
callMy ebp, _GetCurrentProcessId_
cmp eax, ebx
jne @F
push 0
push 4F5Eh
push WM_COMMAND
push [esp+30h]
callMy ebp, _PostMessageA_
popad
xor eax,eax
ret
@@:
popad
mov eax, 1
ret
end START
[培训]内核驱动高级班,冲击BAT一流互联网大厂工作,每周日13:00-18:00直播授课