FreeMp3 Ripper 2.6 – Exploiting with EIP overwrite (almost SEH)
As I study for my OSCE (from Offensive Security) I’m at a point that I’m browsing exploitDB looking for applications to test out my exploit skills. I find applications that are known to be exploitable and then I attempt to create the exploit blind. For todays blog post we’ll be discussing the application Free Mp3 Ripper (http://www.freerip.com/). After a little hard work I was able to create an mp3 file which would generate a reverse shell. …Lets begin
- After downloading and installing the application I began with the usual, attempting to write a series of “A”s to see if I could cause a crash. As this is a non network based application these A’s came in a file with an “mp3” extension.
data:image/s3,"s3://crabby-images/cd526/cd526dcfe253462eec961e8edfb6c763d5bddcf4" alt=""
2. Playing around with the applicaiton I opened the exploit.mp3 from the applicaiton and found that it crashed! …upon inspection with that appeared to be an SEH (structured exception handler) overwrite ….more on this later.
data:image/s3,"s3://crabby-images/0213c/0213c9af9086d91c51721df57f75a2317a01e24f" alt=""
data:image/s3,"s3://crabby-images/51bb4/51bb49ad5939c0caee1f720c64efebccdc273f2d" alt=""
data:image/s3,"s3://crabby-images/9e76c/9e76c2a3c12538de9720ecfed56c9bcbadfe72e8" alt=""
3. Having believed to have found my path towards exploitation I attempted to identify where SEH was overwritten using a 5000 metasploit pattern.
data:image/s3,"s3://crabby-images/2865c/2865ce575ae8fdfcbc9f0cd0668c623a9820178c" alt=""
data:image/s3,"s3://crabby-images/32cbd/32cbd5e88d8f05ab0a6bfc2efe269de09410de3e" alt=""
4. I then went about trying to identify any bad chars
data:image/s3,"s3://crabby-images/943b2/943b2c50f0855d82b8a16bcef581783e2b46a2cd" alt=""
data:image/s3,"s3://crabby-images/91934/9193403d28a71bb394cf0e7bca4798d4bc814c9d" alt=""
5. I then went about trying to find a pop pop ret that exists within a module that wasnt ASLR or DEP protected.
data:image/s3,"s3://crabby-images/8991b/8991b5c78a27dd629e2158360d63505bef3ab5e3" alt=""
A rerun the exploit seems to show it working with the memory address I specified!
data:image/s3,"s3://crabby-images/a047d/a047d97753e045dbbec56347d25efd8032abeac0" alt=""
PAUSE!
data:image/s3,"s3://crabby-images/10342/103422f40c64cc452a6458c67e0b98293a4cc528" alt=""
At this point I tried inserting some shell code and had noticed I couldnt consistently trigger SEH. As of today I still dont know why other than I just couldnt anymore. I dont think it was due to a bad characater but the behavior deffently changed once i put mroe characters into my 5000 buffer. I burned a day of messing with this when i backed up and attempted to find a different path.
6. Going back to the drawing board I started expermiting with buffers of varying lengths and eventually found that at <> I could directly overwrite EIP.
data:image/s3,"s3://crabby-images/b082e/b082eda4adb001e8c51bde9e338b58eeb6ec6fe9" alt=""
7. Proceeding on round 2, i confirmed still no bad characters
8. I then eventually constructed the following buffer which landed me in a very small space.
(sorry missing screenshot)
9. reviewing the stack I found that about 200 bytes backwards led to my set of A’s. To get there I crafted a jump 200 to ESP and replaced my A’s with NOP’S
mov eax,esp
sub eax,200
jmp eax
data:image/s3,"s3://crabby-images/7278f/7278f68d2d8776a0f4af57d3b3b2b2f3423540d4" alt=""
data:image/s3,"s3://crabby-images/c68bc/c68bcaa7bfc4512060738975061f94cf1a153eae" alt=""
10. Having plenty of space I then went about creating a reverse shell.
data:image/s3,"s3://crabby-images/eb558/eb5585232b02d2674efe85239eae3d11176d5846" alt=""
data:image/s3,"s3://crabby-images/7c39e/7c39e50b381e66f5e262f9c1930995ef83f79e2c" alt=""
11. Foiled again….when I ran my reverse shell it didnt work 🙁
data:image/s3,"s3://crabby-images/5dadd/5dadda64fa9532fc7f2df88a198df36d5eeea15b" alt=""
12. It took me a while to realize that I needed to align my stack. So i placed an adjustment to ESP directly after my jump to my NOP sled.
data:image/s3,"s3://crabby-images/883a7/883a76f8f560ebf9fbf0259ebbd206e2ab3ed727" alt=""
data:image/s3,"s3://crabby-images/5becd/5becd45ac9b32235ee3fb466483a778af98e28d6" alt=""
data:image/s3,"s3://crabby-images/febad/febad64fe755f1859402df907571c646f918af25" alt=""
13. Trying it again and I was able to catch my reverse shell!!!!
data:image/s3,"s3://crabby-images/7c56f/7c56f48d5664eabc77ad420e54879fe6a6eeb9af" alt=""