ANTIVIRUS EVASION /Metasploit Loader (III): loader64.exe (x64_64 bits)
- Layout for this exercise:
data:image/s3,"s3://crabby-images/808aa/808aa737c67fcca82596c0f1881bea4064605026" alt=""
- This exercise is based in the previous one:
http://www.whitelist1.com/2018/02/metasploit-loader-i-loaderexe-x8632-bits_27.html
1 - Adapting the source code to the x64_64 bits architecture
- The goal of this exercise is to adapt previous example of Windows 10 x86_32 bits to the x64_64 bits architecture.
data:image/s3,"s3://crabby-images/e4493/e4493ef636889e152e7dd0515b588b823c9b9e33" alt=""
- The technical explanation of why and how to modifiy the source code for the new architecture is here:
https://github.com/rsmudge/metasploit-loader
https://dev.metasploit.com/pipermail/framework/2012-September/008664.html
- For the x86_32 bits architecture:
data:image/s3,"s3://crabby-images/3ed66/3ed66fcfaaf11b5da5db5d78b9fad2b0c7b6f4cd" alt=""
- For the x64_64 bits architecture:
- To sum it up, the x64_64 bits architecture uses 10 Bytes for the RDI register: a \x48 hexadecimal must be prepended, keeping the bytes of the x86_32 bits case (BF 78 56 34 12), and ending up with \x00s.
- Editing main64.c to reflect these changes:
data:image/s3,"s3://crabby-images/c13a5/c13a51b2b824615bd9a799d9b15ed04fa2ae6a4b" alt=""
- The first change is to amplify the buffer up to 10 Bytes. The old code:
data:image/s3,"s3://crabby-images/bafff/bafffa021a5fe6032c2ac96b25cc2b1460bbb55b" alt=""
- The new code:
data:image/s3,"s3://crabby-images/bf0e3/bf0e3c11125dc67875c7ad45e5277cbfe033b178" alt=""
- The second change is to prepend with 0x48. The old code:
data:image/s3,"s3://crabby-images/2f4a0/2f4a017357f5140b66968b277c28aad2fc6e6c03" alt=""
- The new code:
data:image/s3,"s3://crabby-images/7b311/7b3119ba41b849eea7eb9a29f5dd2366eb6c93f6" alt=""
- Also, updating the buffer expansion from 5 to 10, as before. Old code:
data:image/s3,"s3://crabby-images/689e6/689e61f3b56d842beb000a5b3b67b6d20551b5be" alt=""
data:image/s3,"s3://crabby-images/5e65b/5e65bb0c1a2f29597cddb4203fb53a9e56fd6000" alt=""
- New code:
data:image/s3,"s3://crabby-images/58fe4/58fe4ea38455cf3421ec96484370648bba54696b" alt=""
data:image/s3,"s3://crabby-images/3d7ed/3d7edad0d3d01b4776bf2b544f42fa12f08cb9a4" alt=""
- Finally, the whole altered section looks like this:
data:image/s3,"s3://crabby-images/df3c1/df3c158a2f4bd7a0803901c9870572ba37039c98" alt=""
- Cross-compiling with mingw32 (version for x64_64 bits):
data:image/s3,"s3://crabby-images/08e60/08e6045e86c95b195cc7d4a218d333fa6bc9f457" alt=""
- A new executable loader64.exe is created:
data:image/s3,"s3://crabby-images/a0c48/a0c48523dd60e8099653e9dc4dce2dd1799d7dd5" alt=""
2 - Running the payload at the victim side
- Setting a simple web server at Kali:
data:image/s3,"s3://crabby-images/10445/1044571ca07752ea997d6d5cf7114e8cf9874eb5" alt=""
- Downloading the executable loader64.exe to Windows 10:
data:image/s3,"s3://crabby-images/545f8/545f8076425c3de4c57c8381a5764bcbb70057f6" alt=""
data:image/s3,"s3://crabby-images/d4b30/d4b309209e6e92cfc66e8b7205056c766a84269b" alt=""
- Setting up a Metasploit handler session at Kali machine:
data:image/s3,"s3://crabby-images/aaea5/aaea525d74c6c7ced1cf231bd6523a790d5bc8ea" alt=""
- However, when running loader64.exe at Windows 10 the file stops working:
data:image/s3,"s3://crabby-images/1ab67/1ab676195b0cfec316638c4fce665b88de41c84b" alt=""
- Also, a Meterpreter session is created but it dies after a few instants:
data:image/s3,"s3://crabby-images/f42c1/f42c1a96bb295a20418072ed0a1a554df8f24209" alt=""
- Why does this handler session fail?
- The reason is that the payload was established for the x86_32 bits architecture, what is not correct because in this exercise we are dealing with x64_64 bits:
data:image/s3,"s3://crabby-images/97860/978600d451f370c79013d3ea2e6d123168e4b76b" alt=""
- So, the payload must be replaced with the version for x64_64 bits (let's notice the /x64):
data:image/s3,"s3://crabby-images/fb47c/fb47cbea1c63ac5d5fbd899497a527a368f25a9c" alt=""
- Repeating the whole process now the attack is successful. Establishing a Metasploit handler session on Kali:
data:image/s3,"s3://crabby-images/011c6/011c632f1c31ac2f54d0a0a0d1c91ad109cc345a" alt=""
- Running loader64.exe from the victim Windows 10 x64_64 bits:
data:image/s3,"s3://crabby-images/cab49/cab4905677df35aff7333335fdfb7e67f88abc89" alt=""
- Finally the meterpreter session is successfully generated:
data:image/s3,"s3://crabby-images/72525/72525e5ba61348ee50d4af0f18beee30c691e67e" alt=""
4 - Checking the Anti Virus evasion rate
- Checking loader64.exe against Virus Total a rate of 95.5% of evasion success is achieved:
data:image/s3,"s3://crabby-images/bc3ed/bc3ed7ae15a94b3337fc48dc6e826b5609dc2a6c" alt=""
- Checking loader64.exe against No Distribute, a rate of 100% of evasion success is achieved:
data:image/s3,"s3://crabby-images/232d6/232d66082ebd4647543ab686ca7b0c4d6df3d1e3" alt=""