HTTP BASIC AUTHENTICATION BRUTEFORCE ATTACK WITH NSE (NMAP SCRIPTING ENGINE)
- Layout for this exercise:
data:image/s3,"s3://crabby-images/3cb12/3cb123ffbf46f3aa205797725d533302a645de2e" alt=""
- This exercise is based in the previous post Setting up HTTP Basic Authentication.
- The Nmap http-brute script is part of the NSE (Nmap Scripting Engine) and performs brute force password auditing against http basic, digest and ntlm authentication.
- Some of the possible arguments are:
http-brute.hostname = sets the host header in case of virtual hosting
http-brute.method = sets the HTTP method to use (GET by default)
http-brute.path = points to the path protected by authentication
- For more information about this NSE script:
https://nmap.org/nsedoc/scripts/http-brute.html
- In this example we are pointing at the resources identified by the URL www.whitelist.com/basicauth/
- Let's suppose simple credentials, for the ease of this exercise:
username = admin
password = ababa
- Creating users.txt and passwords.txt, both stored into the root(/) folder:
data:image/s3,"s3://crabby-images/bf729/bf729413b81dfa0419acd88f9cecd450606be8d0" alt=""
data:image/s3,"s3://crabby-images/ccc2c/ccc2c600854fc59635f7ff369cf68938575d802b" alt=""
data:image/s3,"s3://crabby-images/b280f/b280f8291350ea723e676b1664a2760de2ada71b" alt=""
- Launching the http-brute script with the right options, the brute force is successful in just 0.08 seconds:
data:image/s3,"s3://crabby-images/9c2a0/9c2a01aa78778caa3c6ab3f1e7fc5cc826e5b4d1" alt=""
- Checking that the credentials are correct:
data:image/s3,"s3://crabby-images/7d3f7/7d3f7896f3b5a911509542438160a2ef4b74f8ed" alt=""
data:image/s3,"s3://crabby-images/2325a/2325a360f4f811dfd2c039b366d59b4a4700211e" alt=""
- Note: in this exercise a very simple combination of username:password has been used, because the purpose was just to illustrate the usage of the attacking tools. However, in real world there are available complex lists of combinations of username:password that can be used for performing dictionary and brute force attacks. The Kali command #locate wordlists provides many available wordlists, for instance into the folder /usr/share/wordlists