Updated Molebox unpacker

kao

During last year, the most common complaint on this blog was "your Molebox unpacker cannot unpack this crazy big EXE of MMORPG game X, Y or Z."

Sounds like an easy problem to fix, right? Well, that's not true - but I finally did it!

TL;DR:

In the rest of the post I'll describe the obstacles I had to overcome while solving this seemingly simple problem.

Delphi TMemoryStream limitation

First, unpacker is written using classic (non-.NET) Delphi and compiled as x86 executable. And standard Delphi streams are retarded. TMemoryStream uses GetMem - which ends up somewhere in Delphi memory manager and VirtualAlloc. That doesn't work well with 800+MB files.

I ended up with implementing custom stream backed by temporary file (CreateFile with FILE_ATTRIBUTE_TEMPORARY | FILE_FLAG_DELETE_ON_CLOSE).

Pointer magic

Since the original unpacker was using TMemoryStream, the whole file was loaded in memory as a continuous memory block and I could easily read/write each byte of file using pointers. Something like this:

function Decode_Stage2(p: pdword; size: dword; key: dword): dword;
var
   d: dword;
begin
   result := 0;
   d := 0;
   while d < size do begin
      key := key * $19660D + $3C6EF35F;
      p^ := p^ xor key;
      inc(p);
      inc(d, 4);
   end;
end;

...

Decode_Stage2(pointer(dword(f.fImage.Memory) + f.RVAToOffset(startAddress - f.NtHeader.OptionalHeader.ImageBase)), endAddress - startAddress, decryptionKey);

Guess what? Files don't work that way.. 🙁 I had to do a full and complete rewrite of all those methods.

Zlib conflicts

Original unpacker was compiled with Delphi 3. Delphi 3 didn't have Zlib library, so you had to supply your own Zlib implementation. But it won't compile with new versions of Delphi, giving error message

Unit Graphutil was compiled with a different version of zlib.TZDecompressionStream.

The solution was to get rid of my Zlib implementation and rewrite all methods that deal with decompression.

ANSI strings

In Delphi 3 all strings were ANSI. Starting from Delphi 20072009, strings are Unicode. Since Molebox internally uses ANSI, it required changing quite a few structure definitions and rewriting several string manipulation routines. It's a lot of fun (and source of the most obscure bugs), trust me!

Conclusion

I hope you find this unpacker useful. But if it doesn't work for you, please send me an error report with all the details you can and I'll try to fix it. Have fun!

134 thoughts on “Updated Molebox unpacker

  1. hello!
    this unpacker helps me alot! however, i find that it can't process Japanese and chinese character correctly. it just put out some meaningless lines in logs, and the file name was replaced by underlines("____.jpg",etc.). because of this, some files was overwritten and missing, can you fix this?
    here are part of logs:

    [i] Extracting Graphics\Maps\Mazes\570_ÎåÖØÊÔÁ¶ËÀÍöÂÝÐý.png
    [i] Extracting Graphics\Maps\Mazes\571_ÁùÖØÊÔÁ¶±±·ç±ùÔ­.png
    [i] Extracting Graphics\Maps\Mazes\572_ÁùÖØÊÔÁ¶±±·ç±ùÔ­.png
    [i] Extracting Graphics\Maps\Mazes\573_ÁùÖØÊÔÁ¶±±·ç±ùÔ­.png
    [i] Extracting Graphics\Maps\Mazes\574_ÆßÖØÊÔÁ¶Ä§»ÃÉ­ÁÖ.png
    [i] Extracting Graphics\Maps\Mazes\575_ÆßÖØÊÔÁ¶Ä§»ÃÉ­ÁÖ.png
    [i] Extracting Graphics\Maps\Mazes\576_°ËÖØÊÔÁ¶¹âÖ®½×ÌÝ.png

    1. Molebox 2.x doesn't support Unicode properly, so the non-English filenames are usually badly damaged anyway.

      Could you please upload your files to mega.co.nz or mediafire.com and send me the link? I will try to improve my unpacker and will let you know when it's done.

        1. I wasn't able to run your file, it keeps giving error messages in some language I don't understand (Chinese?).

          Please try the hotfix version: https://www.mediafire.com/?t4acraaxas6pact - it should work "better".

          But if it still doesn't work correctly, please help me to get your file running on Windows 7 or Windows XP inside VMWare. I'm specifically interested in regional settings, installed languages, etc.

    2. Use EnigmaVBUnpacker for unpack this exe but not obtain results Ok
      Is possible unpack ?
      Thanks for help

      EnigmaVBUnpacker v0.41a, compiled on 22-04-2017 20:30
      Supports Enigma Virtual Box v4.10..7.70
      Latest version always on {hidden link} and {hidden link}

      [+] Filename: C:\Program Files (x86)\Offboard_Diagnostic_Information_System_Engineering\Odis_Cracked.exe
      [+] MD5: 0523d423788bb17934546c8d5c7dfb80
      [+] x86 executable
      [x] Expected section name ".enigma2", found ".data"
      [x] This file is not protected with Enigma Virtual Box or is hacked.

  2. Hello, Mr. Kao, thank you for the program, it works for me, it works great! * - * emm if not a lot of hassle .. can you help me with a program I have this packaged with UPX you know of ollbyg can help me thanks 🙂

    1. Dear Roger,
      Here is a quote: "UPX has a built-in feature for unpacking unmodified executables packed with itself." from {hidden link} so you can just go to {hidden link} in order to get the latest version of UPX in order to unpack you're executable.

      P.S. If you need help finding the correct command to do so - don't forget to ask google.

  3. Hey Kao I just wanted to say that I've been spending a bunch of time reading your blog recently and wanted to thank you for all the info you put out there.

  4. Hello can you help me please !! I want to unpack an .exe file but it is packaged with aspacker and searched for programs all over google and not found eh and as you did for molebox I was wondering if you can create a program that will unpack aspack programs please!

      1. Thanks for answering me quickly look in google but it does not work for me 🙁 thanks for the molebox unpacker works me 100%

    1. My unpacker works only for Molebox v2.x.

      Molebox Virtualization Solution is completely different program. I have an unpacker for it but it is not public yet.

  5. Out of interest, why did you decide to use Delphi at all - is that just what you built v1 in, or is it more suitable for the task than .NET?

    1. Plenty of reasons:
      * 10 years ago .NET wasn't that popular. It wasn't preinstalled on WinXP, etc, etc.
      * When you're dealing with custom data structures/encryption/compression algorithms, it's much easier to reimplement them in native code.
      * To make unpackers, you need some sort of PE file manipulation library. I happened to have written one for Delphi already. 🙂

  6. kao - 2017-03-16 at 09:30
    I have an unpacker for it but it is not public yet.

    hey kao You can contact me? {email_removed}
    I need unpacker in these files so I can set up my online mu server...
    I want you to help me out of unpack this main.exe

    I'm new to this cracker area xD
    {link_removed}

  7. hi,kao

    i send file to your email,please check it,thanks
    i think the file is pack with molebox virtualization solution
    can you unpack it and give me unpack files?
    thanks~

    1. You're right, it is packed with Molebox Virtualization Solution. I don't have time to look at it now, maybe next week..

  8. Hello, Kao. I have a program now, use your program can unpack data successfully. However, there is a problem, the file name contains "_". I am sure that these underscores are Chinese characters, is there a way to solve this problem?
    Thank you

      1. Then I have a question, whether this program open source? I would like to try to change into C++, and learn about.

    1. Read the comments above - the unpacker for Molebox Virtualization Solution is not public. I am still working on it when I get some free time (which is not a lot).. 🙁

  9. Hi,

    your program gets a Out of Memory Exception as soon it hits 1500MB Memory allocated.
    Is there a workaround for this?

    1. This is not a place for begging.

      If you continue this way, I will have no other choice but to ban you from commenting. Please consider this your final warning.

  10. Hello, and thanks for this tool. I can´t unpack moleboxed exe with external data packages, the data is not in the executable, and I can´t scan the data files itself, have you done something with this type of "packaging"? Thanks!

    1. In general, it should work automatically when unpacking main EXE. Something like this:

      ...
      [i] BOX wildcard = [*.rpt]
      [i] Checking file = dataN.rpt
      [i] Decrypting File System
      [i] Verifying File System MD5
      [i] Parsing File System
      [i] Total files: 16
      [i] Extracting DataTable\en-gb\CashShop.edf
      [i] Extracting DataTable\en-gb\Character.edf
      ...

      If it doesn't work for you, please upload EXE + all data files to mega.co.nz or mediafire.com and send me a link. I'll take a look and try to solve the issue.

  11. Help me please unpack this .exe with your program but at the time of using this file in my game I can not log in

    Can you help me unpack it at 100% please weigh 2.5mb

    {link_removed}

    1. Please don't make 10 comments with the same request. Any comment with a link inside goes to moderation queue and I need to approve it manually.

      My unpacker works just fine:
      minifighter

      Take all 4 extracted files: Client_unpacked.exe, ACDC.dat, MHPClient.dll and Minifighter.dll, put them in the folder with your game and then your game should work. If it doesn't, it's some problem with the game, not with my unpacker.

      You can try renaming file Client_unpacked.exe to Client.exe and see if that helps.

  12. Hello friend can you help me unpack a file packed with Microsoft Visual C ++ v8.0 2005 please help me !!

    {removed}

    1. No. This blog post has nothing to do with Microsoft Visual C++.

      This is your final warning. If you make another off-topic comment, you will be banned.

    1. If you can't write proper problem description, I can't help you.

      Make some screenshots, upload your files to mega.co.nz and then I will try to help.

  13. Hey Kao, great job

    I get a

    [+] MD5: 117ce633ceb20f570712d92eabd0c1f5
    [i] Molebox Pro v2.2570
    [i] Loading control information
    [x] Signature seems to be invalid. File is cut? (F8E95781 / B3095878)

    Is there a way to extract it?

    1. If you could send me a link to the file, I'll take a look. It might be a broken file or a bug in my unpacker.

  14. {link_removed}
    I have try other pack in above site, all the same result.

    if u can not use pan.baidu , u can also use
    {link_removed}

    1. Thank you, I will look at it.

      BTW, comments with links inside are hidden from public. No need to post the same comment again and again. 🙂

    2. Latest version works fine - but it needs a lot of memory and lots of disk space:
      After finish

      Log from the torrent file: https://pastebin.com/DyE1uqhy

      If it doesn't work for you, please make screenshots, explain what exactly you did and send me an email (see bottom of the page). I will try to find and fix your problem.

  15. sorry , it seems that it is ok now. It work on local driver ,
    but in remote dirver like samba or virtualbox share folder it reports [x] EXCEPTION EWriteError
    I move the exe to local drivers , it works ok.

    1. I'm happy that you have solved it now. 🙂 Later I'll check my unpacker with the network drive and see if I can find and fix the problem.

  16. Hello sir i would like to ask if your program can work on unpack data extension and link to .exe

    like for example

    Ran.exe
    File001.data
    File002.data
    File003.data

    the main files was packed in File 001-File 003.data

    the Question is can i able to unpack it?? thank you for your Response..

  17. Hello. Awesome work on Molebox unpacker! However I still can't unpack 1 executable file. Can you, please, check and point what version of Molebox was used? Thanks in advance!
    {link removed}

    1. That's not Molebox at all. It's Thinstall v2.501.

      EDIT: first layer is Thinstall. When you unpack that, you will get ~200 files. From those files, mugen.exe.exe is packed with Molebox and data are stored in file TWNM895..... My Molebox unpacker will work just fine with those.

    1. The file you attempted to download was determined to be dangerous. For your protection, MediaFire does not enable distribution of dangerous files.

      Please upload your file to mega.co.nz and I'll look at it. 🙂

    1. It is packed by Molebox Virtualization Solution. It is a different software and not supported by my unpacker.

      Your files unpacked: {link_removed}

  18. I can not run thanhlong_unpack.exe like thanhlong.exe pak, is there a way to solve the error help me ?, i need to run thanhlong_unpack.exe, thanks you
    link img: {hidden link}

    1. You did not give me all game files, so I could not test the unpacked EXE.

      If you can upload full game client to MEGA, I will look at it and fix the unpacked EXE.

    1. Your EXE file is multi-packed. First, it was packed with Enigma Protector. Then it was packed by Molebox Virtualization Solution. Such files are very hard to unpack automatically.

      Here is the EXE file that should work: {link_removed}
      If it doesn't work for you, learn how to unpack Molebox VS and Enigma Protector yourself. 🙂

  19. Thank you very much, you solved my problem very well, the file I downloaded to the computer, you delete the mega.nz path you upload in the home, thank you

  20. Thank you for this tool. However, half my files I need to decompress are old versions, so this result always comes up:

    Is there a way to solve this? In case you need a link to the file just ask me and I'll upload it.

    Regards

    1. Sure, just upload the file to mega.co.nz and post a link in comment.

      Comments with links are moderated, so only I will be able to see it.

      1. Gracias por la ayuda, aunque serían muchos más archivos que el que voy a subir (por si había algún método general), pero mientras subo aquí este. El ejecutable en concreto es El_Libro.exe.

        {link_removed}

  21. Oops, sorry, I answered in spanish. Translation:

    "Thanks for your help, though there are many files I have to open instead of just one (just in case there was a general method to apply to everyone), but here I send one. The .exe is El_Libro.exe.

  22. You help me get the default files, it's locked IP and I can not use it.
    Locked files include: AccountServer.exe, BackupServer.exe, DBServer.exe, LoginServer.exe, LogServer.exe, MailServer.exe, MapServer.exe, TradeServer.exe, VTServer.exe.
    link: {link_removed]
    Hope you will look over it once, thank you.

  23. Please help me with this unpacking using Molebox Virtualization any Idea how to unpacked this sir?
    Thank you for your response and another how can i donate your work sir for good services?

    - RAGE

  24. hello sir i have client here, i tried to unpack using your demolition but ive got an error could you please me with this i will send your email..

    Gracias

    1. Your file is packed with Molebox Virtualization Solution. That is a completely different software than original Molebox and is not supported by this unpacker.

  25. Can u help me to unpack this? Please ? {link_removed}
    Doesn t work it said me it s not probably molebox version, but i scan with rdg it s molebox 4

    1. Charmeine, this unpacker is for Molebox version 2.x.

      Molebox version 4.x (also called Molebox Ultra, Molebox Virtualization Studio or Molebox VS) is a totally different product and my unpacker doesn't support it.

    1. I just checked, unpacker works just fine. Please try again and read all the messages carefully.

      If you still can't make it work, please post a screenshot of unpacker with the error message.

    1. All links are working for me.

      Maybe MEGA is blocked in your country - but that is not my problem. You will need to find a VPN or other solution to bypass it.

  26. Hi Kao,

    Good day!
    I would like to ask you for best compiler/virtualization as well as PC securities, how I can contact you.

    Please reply.

  27. I have the same problem, it just shows: Not a molebox or unknown version. If you can tell me your e-mail I can send you the file thanks.

  28. JuraCrazy Modder

    I am having a problem with a Japanese program called SCWU, the program reports that the molebox present in SCWU.exe is modified or unknown I need help to unzip this 2d maker fighte engine...
    help me too

  29. Hi. I was unpacking a file (.exe). after that when i run the app, i will see this message:
    ---------------------------
    Component 'ImpulseAniLabel.ocx' or one of its dependencies not correctly registered: a file is missing or invalid.
    what should i do? please help me.

    1. Hi dear kao
      Thank you for your comment. I had done your suggestion but after that the software says :--------------------------- Component 'FAST2010.ocx' or one of its dependencies not correctly registered: a file is missing or invalid ------------
      Again, I try to fix it in your way. It shows --------------
      ------- DllRegisterServer in FAST2010.ocx succeeded. -----------
      But it doesn't work. the software says fast2010.ocx has problem. Would you please give me some solutions? I appreciate.

      1. the software says fast2010.ocx has problem

        What's the exact error message?

        Without seeing the software, I can only guess what's causing the problem. So, again, could you please upload your software to mega.nz or mediafire.com and post the link?

  30. message:
    Component 'FAST2010.ocx' or one of its dependencies not correctly registered: a file is missing or invalid.

    I will send it to your email.

        1. As I said - I haven't received anything. Nothing even in a "Spam" box.

          Please post the link in comments here. http/https links posted by visitors are visible only to me, nobody else can see them.

          1. Dangerous File Blocked
            The file you attempted to download was determined to be dangerous. For your protection, MediaFire does not enable distribution of dangerous files.

            MediaFire is blocking the download. Are you trying to send me malware?

          2. Come on, are you kidding me? This is a software that we use it in hospital in order to calibrate our equipment. I want to find a way to facilitate the calibration process and crack this software. I can not prove you that this is not a malware. If you want you can download it from
            {hidden link}
            and run it in virtual machine (windows XP). Thank you in advance.

          3. Sorry, Mediafire is sometimes like that. MEGA is much kinder and tolerates strange files.

            My steps in Windows XP virtual machine:

            • unpacked your software using latest demoleition.exe .
            • copied ASL_unpacked.exe to the _extracted folder
            • opened cmd.exe and navigated to _extracted folder
            • ran the following command:for %F in (*.dll,*.ocx) do regsvr32 /s %F. It will take all DLL and OCX files and try to register them properly. "/s" ensures that no error messages will be shown.
            • after that ASL_unpacked.exe runs just fine, showing me the registration dialog

            Since I don't have a valid license and your hardware, I can't actually verify that every function works. But that's a different story.

  31. Hi again. The problem has been solved. Words are not enough to say thank you. It's kind of you to spend time in order to solve my problem.

Leave a Reply

  • Be nice to me and everyone else.
  • If you are reporting a problem in my tool, please upload the file which causes the problem.
    I can`t help you without seeing the file.
  • Links in comments are visible only to me. Other visitors cannot see them.

three  −   =  1