DNS ENUMERATION AND ZONE TRANSFER WITH NSLOOKUP, HOST, DNSRECON, DNSENUM, FIERCE AND NSE
- Layout for this exercise:
data:image/s3,"s3://crabby-images/80210/80210b836f05a78390f2207561fdb303b6f54251" alt=""
1 - Introduction
- DNS servers are some of the best sources for gathering information about a domain or an organization.
- DNS servers contain DNS and mail information for the domain with authority over what is provided when public requests are made from the Internet.
- Due to the abundant and interesting information contained in the DNS servers DNS Enumeration is one of the most critical steps while gathering information about a target.
- DNS Zone Transfer, also sometimes known by the inducing DNS query type AXFR, is a type of DNS transaction.
- DNS Zone Transfer is one of the many mechanisms available for administrators to replicate DNS databases across a set of DNS servers.
- A zone transfer uses the Transmission Control Protocol (TCP) for transport, and takes the form of a client–server transaction.
- The client requesting a zone transfer may be a slave server or secondary server, requesting data from a master server, sometimes called a primary server.
- The portion of the database containing the list of all DNS names is the zone file.
- The data contained in a DNS zone may be sensitive from an operational security aspect.
- This is because information such as server hostnames may become public knowledge, which can be used to discover information about an organization and even provide a larger attack surface.
https://en.wikipedia.org/wiki/DNS_zone_transfer
2 - nslookup
- nslookup is a popular tool that queries name and email servers in the Internet given the domain:
data:image/s3,"s3://crabby-images/03457/03457aca0698cf6e7b0e4907ad3e7b4798fb53a8" alt=""
data:image/s3,"s3://crabby-images/129c4/129c480f43dc1d70455755d43021ce42281aa558" alt=""
- Applying the NS query option for name servers:
data:image/s3,"s3://crabby-images/9b851/9b851a2c20aef132089c3f9912e7131c9a334d35" alt=""
- Applying the MX query option for mail servers:
data:image/s3,"s3://crabby-images/0edd9/0edd99222886f8c1b3618d203f333e9f338ed92d" alt=""
- Applying the ANY query option for both name and mail servers:
data:image/s3,"s3://crabby-images/e301a/e301afee560afa03701e1e7359f8d006dda8710a" alt=""
3 - host
- host is a Linux command that performs powerful DNS lookups given a domain name:
data:image/s3,"s3://crabby-images/46bd2/46bd2917379e8ab1796d4cb07b09372dc6ff6043" alt=""
data:image/s3,"s3://crabby-images/3e9f5/3e9f512f04385afce18c2c3d9d85b7b51171498d" alt=""
- Without any other parameter host provides help:
data:image/s3,"s3://crabby-images/918a5/918a5226eef8e3c443af0847d825a58b32181047" alt=""
- Looking for name servers (-t type ns):
data:image/s3,"s3://crabby-images/2544c/2544cf40fe3a28ac0d0597dc8422618c7ea64bf5" alt=""
- Looking for email servers (-t type mx):
data:image/s3,"s3://crabby-images/61b7f/61b7f695a05208111fa84732179fc5403e512752" alt=""
- Looking for web servers :(-t type www):
data:image/s3,"s3://crabby-images/442d5/442d5e23abb8367b8139e965e75bc3693c7fb03c" alt=""
4 - DNS Zone Transfer with host
- Now, let's use host for a little more complicated task like a DNS Zone Transfer.
- First, let's try with the previously enumerated ns1 name server. The zone transfer fails:
data:image/s3,"s3://crabby-images/dd83d/dd83d876e6512b7fb34616c2046a9769ae7ce4db" alt=""
- However, the zone transfer with ns2 is successful:
data:image/s3,"s3://crabby-images/7a91d/7a91dbe46a2801c15a17707c237038cac948c037" alt=""
- Finally the zone transfer with ns3 also fails:
data:image/s3,"s3://crabby-images/dd0a7/dd0a7bb5d986c86abc84b473edb861d065017d1d" alt=""
- The result of the successful DNS Zone Transfer with ns2 is a full dump of the zone file for the whole domain, providing us a list of IPs and their corresponding DNS names.
- Let's try entering into a browser some of the IPs obtained from the DNS Zone Transfer:
data:image/s3,"s3://crabby-images/69271/69271efb70291ab3440f113f3be3004ad4da3a09" alt=""
data:image/s3,"s3://crabby-images/79e04/79e04a14769fe69b4cc1bc716b0f73ab842e493f" alt=""
data:image/s3,"s3://crabby-images/baa62/baa62719e6437ee4f8914df38f61856e1ffe7460" alt=""
data:image/s3,"s3://crabby-images/7ddcd/7ddcd692561bfd8f5ea0044f76a643b94f91c5a9" alt=""
data:image/s3,"s3://crabby-images/7e9ce/7e9ce25b389a81710a3cd90c99d9d41737855d54" alt=""
data:image/s3,"s3://crabby-images/0b770/0b7702d007437cc33725fb0958b251652c6bff1d" alt=""
data:image/s3,"s3://crabby-images/ac8b1/ac8b11582b0b417b2f3ed232cc84a68eea0aad86" alt=""
data:image/s3,"s3://crabby-images/f1468/f1468d5997c2281929f33b9f907a2dcfd51df3e4" alt=""
data:image/s3,"s3://crabby-images/fd0f1/fd0f1bb0dcc420f879b1fddbd3fdc62fc9eb4f35" alt=""
data:image/s3,"s3://crabby-images/9c94a/9c94a636d354bed6da0a246be0549ca67f4721d3" alt=""
5 - dnsrecon
- dnsrecon is an automated tool consisting of a Python script that can be user for DNS enumeration.
https://tools.kali.org/information-gathering/dnsrecon
data:image/s3,"s3://crabby-images/c8a64/c8a64b4430ae3c4cd2d8fa685db9fc83d4c9178c" alt=""
data:image/s3,"s3://crabby-images/4e50b/4e50b0286eeff2c1accbe5ed521e219c542d9415" alt=""
- Let's see that information provided by dnsrecon is the same as obtained before.
- First, dnsrecon detects the DNS servers ns1, ns2 and ns3:
data:image/s3,"s3://crabby-images/dfb9d/dfb9d4175141a1815c552bc04503eabaf03209ad" alt=""
- Then, dnsrecon tries a successful DNS zone transfer with ns2:
data:image/s3,"s3://crabby-images/194c1/194c15c551d03a4fceac69becd5afaca9bc8076f" alt=""
- Also, dnsrecon tries a DNS zone transfer with ns1 and ns3 with no result:
data:image/s3,"s3://crabby-images/5a3dc/5a3dc11674216f1b174178eabd8d2d554ab0ffca" alt=""
6 - dnsenum
- dnsenum is a multithreaded Perl script to enumerate DNS information of a domain.
https://tools.kali.org/information-gathering/dnsenum
- The output obtained with dnsenum is the same as before:
data:image/s3,"s3://crabby-images/4d0b2/4d0b283cfb88ebd79a1debc54f8db854382b515b" alt=""
data:image/s3,"s3://crabby-images/72187/721873a742dfbaca335d01b3463f4c9c782c9cbc" alt=""
data:image/s3,"s3://crabby-images/17810/17810620b6503c054a7c69a5a7038f3c8b073ffb" alt=""
7 - fierce
- fierce is a Perl base script to perform DNS enumeration. Results obtained with fierce are pretty similar to previous ones:
data:image/s3,"s3://crabby-images/b33ea/b33eabf27230c4df2941e41363dc3d2391da2278" alt=""
data:image/s3,"s3://crabby-images/85d78/85d7897891251c370953fcdc19e367dc1ab912d7" alt=""
8 - Nmap Scripting Engine (NSE)
- Nmap Scripting Engine (NSE) is an addition to Nmap which provides users with scripts to automate several tasks:
https://nmap.org/book/nse.html
- The NSE dns-zone-transfer script provides same output than before:
data:image/s3,"s3://crabby-images/1e65a/1e65ae3e033f51caf59bdb557fb8f4aca35d526e" alt=""
- A little more limited result, because it finds just a list of common subdomains, is achieved with the NSE dns-brute.nse script:
data:image/s3,"s3://crabby-images/318fd/318fd886e0feb8cc16562acf2316bc98eaa4e0bd" alt=""
9 - whois
- whois is a query and response protocol that is widely used for querying databases that store the registered users of an Internet resource, such as a domain name, an IP address block, or an autonomous system.
- Looking for the domain megacorpone.com:
data:image/s3,"s3://crabby-images/7bb1d/7bb1d154df09fb7800b886f48b36e609f580b8b9" alt=""
data:image/s3,"s3://crabby-images/832ca/832cab9514b3eac26f3fdb68e01ced751161f668" alt=""