CAPTURING HTTP BASIC AUTHENTICATION CREDENTIALS WITH WIRESHARK
- Layout for this exercise:
data:image/s3,"s3://crabby-images/0200d/0200d7e4cba4544fa36e761e12647cee087873f1" alt=""
- This exercise is based in the previous post Setting up HTTP Basic Authentication.
- Launching the sniffer Wireshark, the Kali Linux machine is able to capture all packets crossing its interface eth0:
data:image/s3,"s3://crabby-images/de2de/de2de2274f79f402e54581e4de05f0d4314b17d5" alt=""
data:image/s3,"s3://crabby-images/79e27/79e27bf3ea6c4e511bd1d7573d19422c039a9098" alt=""
- Whe the user from Kali tries to access the web page "/basicauth/index.html" the Apache web server responds with the challenge for Authentication requirement. Introducing the credentials:
username = admin
password = ababa
data:image/s3,"s3://crabby-images/2f204/2f204a439c8df97ad6c0a24f613a5da5ae8eb500" alt=""
- As expected the access is successful:
data:image/s3,"s3://crabby-images/778f2/778f2d416fe468c4fbd7c22f144c10384461b619" alt=""
- Setting up a filter that limits packets only to those exchanged between Kali (192.168.1.13) and Ubuntu Apache server (192.168.1.15), we can look into the packets captured by Wireshark.
- Once Kali has sent the correct credentials the server responds with a 200 OK message:
data:image/s3,"s3://crabby-images/90420/90420e7b6c607cb2ec3569de3cb925861e2901b6" alt=""
- However, opening the first packet it is clear that Basic authentication has been used, also displaying the string corresponding to the credentials.
- The credentials have been sent without encryption, but encoded with Base64, and the correspondig string can be copied for further study:
data:image/s3,"s3://crabby-images/93d46/93d460f7dfb54bd62b9288352b5ddd4eec22fbaa" alt=""
- Now, a Python script can be used to decode the Base64 string and reveal the correct credentials: 'admin:ababa'
data:image/s3,"s3://crabby-images/1e7cf/1e7cfefd918ae0a095360bc025d48495f6df96bf" alt=""
data:image/s3,"s3://crabby-images/09a3f/09a3fd1bfdb2bf75071d53a0c3ceef467f93d9b0" alt=""
- Also, Wireshark captures the HTML text response from the server, corresponding to the web page resource:
data:image/s3,"s3://crabby-images/d2879/d28796bd7fa0b82895b59ce38bbfc48238ff2571" alt=""