The following method instead is a bit more advanced and can be used not only for the ZIP archives, but also for other types of passwords like those used for encryptions like AES and blowfish.
Like all my tutorials, I will try to make everything as easy as I can.
Tools:
Signsrch http://aluigi.org/mytoolz.htm#signsrch
Ollydbg or Windbg or any other debugger
http://ollydbg.de/
http://www.microsoft.com/click/services ... =300135395
Optional tools:
QuickBMS http://quickbms.aluigi.org
The example game for this tutorial is Mini Robot Wars:
http://www.bigfishgames.com/download-ga ... index.html
First step - check the files in the folder of the game and start it.
Start signsrch on the process of the game, in this case mrw.exe but you can specify also the PID in case of conflicts.
If the game runs on two processes, you must specify the PID of the second one.
Output of signsrch:
Attach a debugger to the game, the following example is Windbg.
Windbg is faster than ollydbg and more compatible with "some" games, but it's not easy to use like ollydbg and other visual debuggers.
Now it's necessary to put a breakpoint or finding another way to interrupt the debugger when the zipcrypto function is called.
The simplest way obviously is going with the debugger at the beginning of the instruction pointed by the offset visualized by signsrch.
But if you want something more easy you can use the following script for quickbms:
Code: Select all
math quickbms_arg1 -= 3
goto quickbms_arg1
for i = 0 < 5
    put 0xcc byte
next iCode: Select all
quickbms -p -a 0x40426e int3.bms process://mrw.exe*edit* type the command "g" in Windbg for continuing the execution of the game.
The following is an example of that command with Ollydbg in the background:
*edit* Press F9 or click on the PLAY-like button > of Ollydbg for continuing the execution of the game.
Now play the game and wait the debugger.
Ollydbg:
Windbg:
It's quite easy and doesn't need a big knowledge of debugging, moreover if you use ollydbg in which you must do absolutely nothing.
I don't know if exist easiest ways to explain this, but if you know... tell me


