data:image/s3,"s3://crabby-images/cf471/cf471299d90976ead22701a403a66afb1f0bfa36" alt=""
Hack The Box – Legacy Walkthrough
Introduction
This was an easy Windows box that involved exploiting the EternalBlue SMB vulnerability which is part of the MS17-010 security bulletin.
Enumeration
The first thing to do is to run a TCP Nmap scan against the 1000 most common ports, and using the following flags:
- -sC to run default scripts
- -sV to enumerate applications versions
- -Pn to skip the host discovery phase, as some hosts will not respond to ping requests
- -oA to save the output in all formats available
data:image/s3,"s3://crabby-images/4ac6b/4ac6bd36df65d6f9b41a6cb24966aa173ccf9569" alt=""
SMB Enumeration
The next step was to run a Nmap scan on ports 139 and 445 with all SMB enumeration scripts, to further enumerate this service. Command used:
nmap -p 139,445 -Pn –script smb-enum* 10.10.10.40
data:image/s3,"s3://crabby-images/3020e/3020e6769b7462f7cb6367116dfa4c19e41c73cf" alt=""
Then ran another Nmap scan to check for any known vulnerabilities within the SMB service. Nmap has a number of “smb-vuln-msxx-xxx” scripts that can be used to test the SMB service for public exploits.
data:image/s3,"s3://crabby-images/161fa/161fae4a925c28b13488f4189b9e4aff845ec4ae" alt=""
SMB Exploitation
I tried a few exploits for MS17-010 found in GitHub and ExploitDB but most of them did not seem to work, I then finally found the following Git repository – this exploit can use an exe-embedded shellcode, rather
than having to add the shellcode to a Python script like some of the other ones available on ExploitDB.
data:image/s3,"s3://crabby-images/11646/11646b057a6bd8fb7e4340ec2bf28f1ae9e5fa57" alt=""
The first step is to generate some shellcode using MSFvenom with the following flags:
- -p to specify the payload type, in this case the Windows TCP reverse shell
- LHOST to specify the local host IP address to connect to
- LPORT to specify the local port to connect to
data:image/s3,"s3://crabby-images/83c96/83c960a232c01c3b55868ee46e4f61c6570673a7" alt=""
The next step is to set up a Netcat listener, which will catch our reverse shell when it is executed by the victim host, using the following flags:
- -l to listen for incoming connections
- -v for verbose output
- -n to skip the DNS lookup
- -p to specify the port to listen on
data:image/s3,"s3://crabby-images/67f11/67f11562b12f0db79fa0a5f1ac21d40e5e5ddb94" alt=""
Executing the exploit, providing the IP address of the target machine, the malicious executable and the port to be used – this provides with a reverse shell. It looks like the current user already has system-level so no privilege escalation is required.
data:image/s3,"s3://crabby-images/1fe68/1fe687d722a93a81cae0c3c5c2519fb7f40184d3" alt=""
Conclusion
The EternalBlue vulnerability is a very common Windows issue that has affected a large number of systems over the years, it is particularly dangerous as it is extremely easy to exploit and pretty much always results in a full system compromise.