6 Einträge, 1 Seite |
tcpdump -e -q -n -i eth0 ip >/root/logpipe
1
2
3
4
open (LOGDATEI, ">>${logdat}") or die("Dateifehler!"); # Log-Datei öffnen zum schreiben
$old_fh = select(LOGDATEI); # siehe perlfaq5 (How do I flush/unbuffer an output filehandle? Why must I do this?)
$| = 1; # Perl anweisen, die Schreiboperation auf die Logdatei nicht zu buffern
select($old_fh); # sondern direkt auszufuehren
1
2
3
4
open (LOGPIPE, $pipename) || print "konnte $pipename nicht oeffnen\n";
while (<LOGPIPE>) # Zeilen lesen
{
my $logline = $_; # Zeile sichern
tcpdump -l -e -q -n -i eth0 ip >/root/logpipe
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
#!/usr/bin/perl
# ===== Aktiver ARP-Scanner =====
if ($pid1 = fork)
{ # ===== PARENT-PROZESS =====
print "Parent ($$) hat fork 1 durchgefuehrt \n";
if ($pid2 = fork)
{ # ===== PARENT-PROZESS =====
print "Parent ($$) hat fork 2 durchgefuehrt \n";
# ======================= PARENT-CODE ==============================
print "===== PARENT =====\n";
print "== ARP-Analyser ==\n";
print "==================\n";
print "tcpdump : $pid1 \n";
print "nmap : $pid2 \n";
print "reader : $$ \n";
open (LOGPIPE, "/root/logpipe") || die "konnte logpipe nicht oeffnen\n";
while (<LOGPIPE>) # Zeilen lesen
{
my $logline = $_; # Zeile sichern
print $logline; # Zeile ausgeben
chomp($logline); # Zeilenende entfernen
($layer2,$proto,$layer3) = split(/,/,$logline); # Zeile zerlegen
($tstamp,$smac,$d1,$dmac) = split(/ /,$layer2); # Layer2 zerlegen
($d0,$d1,$bytes,$d2,$d3,$aip,$d4,$amac) = split(/ /,$layer3); # Layer3 zerlegen
$bytes =~ s/://g; # Doppelpunkte vernichten
$angriff = ($smac ne $amac); # ARP-Angriff
print "TStamp : $tstamp #\n"; # Zeitstempel
print "SrcMAC : $smac #\n"; # Sollte identisch mit Answer-MAC sein
print "DstMAC : $dmac #\n"; # Sollte dieser PC sein
print "Bytes : $bytes #\n"; # Paketgroesse
print "AnswIP : $aip #\n"; # Sollte der angefragte PC sein
print "AnsMAC : $amac #\n"; # Sollte die MAC des Angefragten sein
if ($angriff) { print "ARP-Angriff!!\n"; }
}
# ==================================================================
exit;
}
else
{ # ===== CHILD-PROZESS 2 =====
die "fehler bei fork2: $!" unless defined $pid2;
print "Child 2 wurde gestartet : $$\n";
# ======================= CHILD2-CODE ==============================
print "===== CHILD 2 =====\n";
print "====== nmap =======\n";
print "===================\n";
while (1)
{
$d1 = `/usr/bin/nmap -sP 10.10.0.1-254`; # ARP-Scan durchfuehren
sleep (1); # Scan-Zyklus
}
print "nmap gestoppt \n";
# ==================================================================
waitpid($pid2,0);
}
exit;
}
else
{ # ===== CHILD-PROZESS 1 =====
die "fehler bei fork1: $!" unless defined $pid1;
print "Child 1 wurde gestartet : $$\n";
# ======================= CHILD1-CODE ==============================
print "===== CHILD 1 =====\n";
print "===== tcpdump =====\n";
print "===================\n";
$d1 = `/usr/sbin/tcpdump -l -e -q -n -i eth0 arp and not ether dst ff:ff:ff:ff:ff:ff >/root/logpipe`;
print "tcpdump gestoppt \n";
# ==================================================================
waitpid($pid1,0);
}
6 Einträge, 1 Seite |