Portscanner mit der Shell

Aus Xinux Wiki
Zur Navigation springen Zur Suche springen

/dev/tcp in Sub-Shell

  • 'bash -c ">/dev/tcp/$ZIEL/$I"' — öffnet eine TCP-Verbindung zum Zielport. → Wahr
  • Die Umleitung '>/dev/tcp/...' wird in der aktuellen Shell ausgeführt. → Falsch
  • Mit 'bash -c ">/dev/tcp/$ZIEL/$I" > /dev/null 2>&1' siehst du keine "Connection refused"-Fehler in der äußeren Shell. → Wahr
  • '>/dev/tcp/...' ist POSIX-standard und in jeder Shell verfügbar. → Falsch

Aufgabe

  • Erstelle 'portscanner.sh' mit Aufruf:
    • ./portscanner.sh <ZIEL> <START_PORT> [END_PORT]
  • Anforderungen:
    • Wenn nur zwei Argumente übergeben werden, prüfe nur START_PORT.
    • Nutze die Bash-/dev/tcp-Technik in einer Sub-Shell, z. B. 'bash -c ">/dev/tcp/$ZIEL/$PORT"' und unterdrücke Ausgabe/Fehler mit '> /dev/null 2>&1'.
    • Ausgabe nur für offene Ports, exakt diese Zeile:
      • Auf dem Ziel: <ZIEL> ist der Port: <PORT> offen
    • Script muss klein, lesbar und ohne externe Tools sein (optional: 'timeout' gegen Hänger).