WINDOWS 7 - BYPASSING DNS BY HOSTS FILE INJECTION
- Layout for this exercise:
data:image/s3,"s3://crabby-images/40be8/40be843cac0241b4f35ae0772e8afed27edd2047" alt=""
- The hosts file is a plain text file used by an operating systems to map hostnames and IP addresses.
- In this
practice we'll se how to inject a crafted hosts file into the
victim machine, so that
the well
known URL www.google.com is redirected to the attacker's
website.
- This is
a case of the so called phishing, where a trustworthy website
is masqueraded by a fake website.
- One of
the keys for this attack to be successful is the name resolution
order performed by Windows systems. First, the Windows 7 looks up
into the hosts file entries. Second, Domain Name System (DNS)
servers are queried.
- For this
reason, if a crafted hosts file is injected into the victim's
machine, the victim would not be able to notice that the web
destination is actually a fake one.
- Let's
start the attack backgrounding the active meterpreter session:
data:image/s3,"s3://crabby-images/c1f97/c1f978447afa2bbd040c237c8bdc0719a8783a5d" alt=""
- Now, the
post explotaition inject_host exploit is used:
data:image/s3,"s3://crabby-images/364c0/364c02427e2a6572616e8fb5115b6db861e89e47" alt=""
- Options
for this exploit:
data:image/s3,"s3://crabby-images/740f1/740f198aeab9f25c02dcdf6ad4e895d350e3403f" alt=""
- The domain to be faked:
data:image/s3,"s3://crabby-images/cece6/cece62ca375e0718ccaf3f2f7af7770c54dcd34d" alt=""
- The attacker's IP:
data:image/s3,"s3://crabby-images/86dcc/86dcc65e73aa940f5b711edcdfdb970a6c1f1474" alt=""
- The
active meterpreter session:
data:image/s3,"s3://crabby-images/2a16d/2a16dd9fdf67c9c105d209ac732fe999735ca1a7" alt=""
- Now, all required options are fulfilled:
data:image/s3,"s3://crabby-images/593ee/593ee310d6dca137d79ea2ce781106ad747431be" alt=""
- The
exploit is launched and successfully completed:
data:image/s3,"s3://crabby-images/a3a06/a3a0662fed24b5c6cc87de512f674d1b2774cb1a" alt=""
- As a
result, back into the victim, the hosts file has got now a new entry,
pointing www.google.com to the attacker's IP:
data:image/s3,"s3://crabby-images/c7f32/c7f324f19a8d2e049ee65b067a14b736ea02f8cd" alt=""
- On the attacker's side, with the purpose of taking advantage of the attack, a web server is set up on port 80, adding a message of welcome:
data:image/s3,"s3://crabby-images/f47a9/f47a9362c495a63531499dd2365dca62d27be204" alt=""
data:image/s3,"s3://crabby-images/4308c/4308ca2f03a433bc4761ecd09a9882502d22d3e1" alt=""
- From the victim's machine, when trying to connect to www.google.com, the connection is redirected to the attacker's website:
data:image/s3,"s3://crabby-images/6f712/6f712068212085ba93adc2f6208109ec2fe79b9e" alt=""
data:image/s3,"s3://crabby-images/39063/39063596c290dc73a79e619a8bafe8fdcef973e2" alt=""
- Let's
notice that this redirection or phising could be done on the victim's
site with any trustworthy type of websites, like banks, email
services, businesss, ... , and on the attacker's side with a fake
website where the victim could introduce valid credentials,
potentially being stolen by the attacker.
- It is
interesting to check the different way that commands ping and
nslookup handle this situation.
- When
ping-ing www.google.com,
the resolution is between www.google.com and 192.168.1.12:
data:image/s3,"s3://crabby-images/6b520/6b52006376f7dd9c0d8165d39dc59b0445ce431a" alt=""
- On the other hand nslookup is a network administration command-line tool available for querying the Domain Name System (DNS) to obtain domain name or IP address mapping.
- In this
way, nslookup only checks for DNS resolution, not paying attention to
the hosts file, and resolves www.google.com into the real IP
216.58.216.228:
data:image/s3,"s3://crabby-images/687d5/687d5feacb04746aade22baca404b93e41e1fa3b" alt=""
- As said before, hosts file is used before DNS resolution by Windows systems.