SECNOTES
- Layout for this exercise:
data:image/s3,"s3://crabby-images/b50c6/b50c6c4de23a59809324e9e64bd81e74e38de837" alt=""
1 - INTRODUCTION
- The goal for this exercise is to develop a hacking process for the vulnerable machine SecNotes from the Hack The Box pentesting platform:
https://www.hackthebox.eu/
2 - ENUMERATION
- SecNotes' IP is 10.10.10.97:
- Scanning with Nmap:
data:image/s3,"s3://crabby-images/2b20d/2b20d29d9125bed0049f0eb0475752ab8d6c359c" alt=""
data:image/s3,"s3://crabby-images/41249/412496873772c58ff509f1cfe16c3c37e5a9028e" alt=""
- Browsing the web server on port 80:
data:image/s3,"s3://crabby-images/39bc1/39bc1b30334087e4cd9752c0e302917f409e5bc1" alt=""
- Registering a new user whitelist:
data:image/s3,"s3://crabby-images/d3e70/d3e70d2c95468e41671169301be5a2b620fb3959" alt=""
- Login as the new user whitelist:
data:image/s3,"s3://crabby-images/5103d/5103de65790e2dd9318b5420a92eee40f266bebb" alt=""
- Secure Notes is a notepad application that stores notes and to-do list with secure password protection using AES encryption and providing quick and easy access using a simple password:
data:image/s3,"s3://crabby-images/e4adb/e4adb16b5c3f6ae23ca94dc3d59d6efeee072e31" alt=""
- The email tyler@secnotes.htb informs about two details:
- user named tyler
- domain secnotes.htb
- Also, it is interesting the .php extension at the login page, revealing PHP is run by the server.
- Confirming the existence of user tyler with a random password:
data:image/s3,"s3://crabby-images/c2cc5/c2cc52faaf43eb3667b8644e63a740d7f8f87761" alt=""
data:image/s3,"s3://crabby-images/5bfe4/5bfe430dd53adf9d9c8b0b0c1de463737a5148f6" alt=""
- Browsing the other web server at port 8808:
data:image/s3,"s3://crabby-images/6b3ce/6b3ce0d660edbe2c71dc12aedfa23ef640f30aa3" alt=""
- Viewing the source we find the image iisstart.png:
data:image/s3,"s3://crabby-images/e0ad0/e0ad00ee0c17bb3cbd58831216ee687c8eacca20" alt=""
3 - EXPLOITATION
3.1 - SQL injection
- "Second order" SQL injection attack delays execution until a secondary query, by injecting a query fragment into a query (that’s not necessarily vulnerable to injection), and then have that injected SQL execute in a second query that is vulnerable to SQL injection.
https://portswigger.net/kb/issues/00100210_sql-injection-second-order
https://bertwagner.com/2018/03/20/how-to-steal-data-using-a-second-order-sql-injection-attack/
- Using wfuzz to help us finding a valid SQL injection:
data:image/s3,"s3://crabby-images/8ae88/8ae8827d4f8dc84904f61b2f8a6ca7f18444bbbc" alt=""
- From the proposed queries the last one ' or 1=1 or ''=' seems easy to apply:
data:image/s3,"s3://crabby-images/83380/833808f0841034dbd453c4aab426732315260d36" alt=""
- Entering ' or 1=1 or ''=' as a new user and password, and later login with those credentials:
data:image/s3,"s3://crabby-images/739e7/739e73b37378ec3776b4fefafadcf0496b28d7d3" alt=""
data:image/s3,"s3://crabby-images/ff185/ff1857b05dfb3d5c1149c9f922cf6316e67ca52c" alt=""
- Now the home page yields credentials for user tyler at the 3rd note named new site:
data:image/s3,"s3://crabby-images/82f58/82f58632e9a160e382642540bfe54da0b9f0dab8" alt=""
data:image/s3,"s3://crabby-images/75e22/75e222e9bb9991d3aeb45acf4f44e8540140cf8e" alt=""
3.2 - Exploiting SMB
- Using credentials tyler:92g!mA8BGjOirkL%OG*& to access SMB service on port 445:
data:image/s3,"s3://crabby-images/c2cd1/c2cd1c6471a3be38c911a71b7940de4cea5b43a7" alt=""
- Connecting and listing new-site:
data:image/s3,"s3://crabby-images/c5265/c52650865429f2a96ed0c0fcec0dbb0d174a22a5" alt=""
data:image/s3,"s3://crabby-images/affb9/affb9f9b82e460188389d3404f8cebaa652c307c" alt=""
- So we confirm that there is a web service at port 8808 where folder new-site contains the image iisstart.png.
3.3 - Getting a remote shell
- First of all let's download to Kali the Windows Netcat application:
data:image/s3,"s3://crabby-images/f2e4f/f2e4f70411c8f633c31c61cd768632651b1a819b" alt=""
data:image/s3,"s3://crabby-images/56b31/56b31eab0d9a712cabb0146826c136810384c43b" alt=""
data:image/s3,"s3://crabby-images/f41a7/f41a75e607a30e5d744a51dbcab5806f776009c2" alt=""
- Also let's create exploit.php, a PHP exploit which goal is to spawn a remote shell with a Netcat connection:
data:image/s3,"s3://crabby-images/9c2aa/9c2aadbb48f6511e39aff1b8913c6286f0490891" alt=""
- Transferring nc.exe and exploit.php from Kali to SecNotes:
data:image/s3,"s3://crabby-images/a6385/a6385a4d4cb204267982f381aed49857b39781ce" alt=""
- The transfer of both files is successful:
data:image/s3,"s3://crabby-images/735cc/735cc36fe1f784b038f36cf7b6161b18933103c2" alt=""
- Setting a Netcat listening on port 5555:
data:image/s3,"s3://crabby-images/c9657/c96578ca57d21708f2800e1d012813726a25d992" alt=""
- Running exploit.php directly on the browser:
data:image/s3,"s3://crabby-images/08c5f/08c5f53379e0894e8ddf657d8650566edf010ca6" alt=""
- A remote shell is successfully spawned:
data:image/s3,"s3://crabby-images/8d505/8d505a6b644c3813ff7b797a7c0986749cef8bd4" alt=""
data:image/s3,"s3://crabby-images/9c087/9c087388031872b07304e68814c4fc9864ee30e9" alt=""
4 - CAPTURING THE 1st FLAG
- Reading user.txt:
data:image/s3,"s3://crabby-images/f13df/f13df12a6ae197f3a6a022c8d368110ec1f48445" alt=""
5 - PRIVILEGE ESCALATION
- Access to Administrator's account is denied, as expected, so we need Privilege Escalation:
data:image/s3,"s3://crabby-images/74eff/74effc12fe58298d1ab096fb52b300a64b57b651" alt=""
- Checking user tyler's Desktop there is a file bash.lnk:
data:image/s3,"s3://crabby-images/d4748/d474808a5cb087f36136b0750d553b0ba8e1a1bc" alt=""
- Windows Subsystem for Linux (WSL) is a compatibility layer for running Linux binary executables (in ELF format) natively on Windows 10 and Windows Server 2019.
https://en.wikipedia.org/wiki/Windows_Subsystem_for_Linux
- Reading bash.lnk the path C:\Windows\System32\bash.exe seems to be interesting:
data:image/s3,"s3://crabby-images/214f7/214f74e8e2dd2d10b011ca50b164a207a0710a47" alt=""
- However the clue is false because there is no bash.exe at C:\Windows\System32:
data:image/s3,"s3://crabby-images/738f8/738f8985c7e1fcb52ee299dd321b87924f6663b8" alt=""
- Let's find real location for bash.exe:
data:image/s3,"s3://crabby-images/32051/320512f23502c8e47cb52c102855330e6c6f83e2" alt=""
- Running bash.exe we get a root shell for the Windows Subsystem for Linux (WSL):
data:image/s3,"s3://crabby-images/d158e/d158e10ae9145e5ab5b7c7d18706512ce02b6e69" alt=""
- Improving the shell:
data:image/s3,"s3://crabby-images/2087f/2087fb4d484fe6e1f3c4da8661ae6d37083c428c" alt=""
- Checking content of root home folder there is the hidden file .bash_history:
data:image/s3,"s3://crabby-images/d2ac8/d2ac8e36edbca7c47e07c37a9a5a86c5786fbe54" alt=""
- Reading .bash_history credentials for Administrator are available:
data:image/s3,"s3://crabby-images/ce70d/ce70d5250a17b996494af7a501c21b1647ea4791" alt=""
- Making use of credentials administrator%u6!4ZwgwOM#^OBf#Nwnh there are two ways of accessing the Administrator's account:
5.1 - Smbclient
- Connecting with the SMB service:
data:image/s3,"s3://crabby-images/96e04/96e04ad63762c5895f657236abfb5e15bc0e2760" alt=""
data:image/s3,"s3://crabby-images/7345e/7345e7200f8dad8cb0809c3cdca11ed829675612" alt=""
data:image/s3,"s3://crabby-images/fe6b8/fe6b8b464acdf92d8d0023fbd5885f9cb2ec9feb" alt=""
5.2 - Psexec.py
- The Impacket Psexec.py Python script helps to get a remote root shell, just by providing credentials for Administrator:
data:image/s3,"s3://crabby-images/0422e/0422eb338344ea733de1ade5b3b07572621db763" alt=""
6 - CAPTURING THE 2nd FLAG
- So we have two options to read root.txt:
- First, transferring root.txt from SecNotes to Kali and reading it locally:
data:image/s3,"s3://crabby-images/42183/42183aa8229d550bef7752562491f53b45db809d" alt=""
data:image/s3,"s3://crabby-images/31374/31374c5be6309b3d7814ba3e11e7dd7c59013f49" alt=""
- Second, reading it from the remote root shell:
data:image/s3,"s3://crabby-images/9831d/9831d5ea536a5b244ad4b4d220975573b646e28a" alt=""