Home / LinuxUser / 2006 / 03 / Tote Links finden

Newsletter abonnieren

Lies uns auf...

Folge LinuxCommunity auf Twitter

Top-Beiträge

Mandriva gibt Distribution in die Hände der Community
(268 Punkte bei 24 Stimmen)
Neues vom Systemd
(161 Punkte bei 4 Stimmen)
Mandriva in Nöten
(161 Punkte bei 4 Stimmen)

Heftarchiv

LinuxUser Heftarchiv

EasyLinux Heftarchiv

Ubuntu User Heftarchiv

Ubuntu User Heftarchiv

Partner-Links:

Shopping
Topsuche
 
Yatego Deutschlands größte Shoppingmall. 10000 Shops,
3.5 Mio Artikel. Alle Bestseller, Servertechnik und Technik Themenwelten.

Notebooks und Netzwerkhardware bei Mercateo günstig kaufen.
Internet Telefonie mit VoIP Telefonen von Gigaset
Das B2B Portal www.Linx.de informiert über Produkte und Dienstleistungen.
Günstige Digitalkameras finden Sie im Preisvergleich.

Webfehler aufspüren

Tote Links finden

01.03.2006 Jeder komplexere Internet-Auftritt bringt im Verlauf seiner Existenz zunehmend tote Links hervor. Mit Linkchecker spüren Sie Verweise ins Nichts ohne große Umstände auf.

Wer größere Internet-Seiten betreut, kennt das Problem mit den toten Links: Externe Seiten verschwinden im Nirvana, beim Aufrufen der entsprechenden Verweise findet der Browser keine Seite. Das Suchen nach derartigen Fehlern im Gewebe des weltweiten Netzes ist oftmals aufwändig – der Artikel verrät Ihnen, wie Sie mit Linkchecker [1] einfacher auf die Jagd nach "Laufmaschen" im Netz gehen.

Zur Installation von Linkchecker greifen Sie am besten auf eine vorkompilierte Version zurück. Für RPM-basierte Systeme wie Suse oder Fedora finden Sie ein entsprechendes RPM-Paket der aktuellen Version 3.3 sowie ein Quellcode-Archiv unter [2]. Benutzer eines Debian-Derivats sollten einen Blick auf [3] werfen oder Linkchecker über apt-get install linkchecker installieren.

Einfache Lückensuche

Die Benutzung von Linkchecker erfolgt über die Kommandozeile nach dem Muster linkchecker Optionen Testobjekt , wobei es sich bei Testobjekt entweder um eine lokale oder eine über HTTP respektive FTP erreichbare entfernte Datei handelt. Die Eingabe von linkchecker www.linux-user.de ist möglich, da Linkchecker die URL-Präfixe http:// bzw. ftp:// automatisch ergänzt. Nutzen Sie das Internet über einen Proxy, teilen Sie das dem Lückensucher über die Umgebungsvariablen http_proxy, https_proxy, ftp_proxy und gopher_proxy mit. Wie Sie die Benutzervariablen setzen, hängt von der eingesetzten Shell ab: Unter der Bash-Shell erledigt dies ein export http_proxy="http://localhost:8080", Liebhaber der Tc-Shell verwenden den Befehl setenv http_proxy "http://localhost:8080". Ein Proxy, der auf localhost am Port 8080 lauscht, leitet die Link-Überprüfung ins Internet weiter.

Wie Linkchecker funktioniert, offenbart eine nicht ganz standardkonforme, einfache HTML-Datei namens test.html: Der Aufruf linkchecker test.html ist zunächst nicht sonderlich erfolgreich – der Lückensucher meldet, dass er einen Link geprüft und keinen Fehler gefunden habe (Abbildung 1). In der Testdatei verstecken sich aber tatsächlich drei Links, von denen zwei ins Nirgendwo führen.

Abbildung 1: Linkchecker hat Probleme mit dem Dateisystem. Er ignoriert gleich zwei Fehler und testet nur einen Link.

Wird die selbe Datei test.html hingegen von einem Webserver ausgeliefert, spürt Linkchecker die fehlerhaften Links auf (Abbildung 2). Die Dokumentation weist zudem darauf hin, dass die aktuelle Version nicht mit JavaScript kooperiert.

Abbildung 2: Fehler gefunden: Im Zusammenspiel mit einem Webserver findet Linkchecker die Fehler, er prüft – inklusive der Datei "test.html" – vier Links und meldet zwei als defekt.

Das richtige Strickmuster

Neben der einfachen Textausgabe erfolgt die Fehlerdiagnose wahlweise auch über die in Tabelle 1 aufgeführten Ausgabeformate. Je nachdem, ob Sie eine Bildschirmdarstellung wünschen oder eine spezielle Ausgabedatei benötigen, wechseln Sie über --output=html bzw. --file-output=html/Dateiname ins HTML-Format. Geben Sie für die Ausgabedatei keinen Dateinamen an, nennt Linkchecker die Datei linkchecker-out und ergänzt sie um den festgelegten Dateityp, zum Beispiel zu linkchecker-out.html. Abbildung 3 zeigt die Browser-Ansicht einer erzeugten Ausgabedatei: Praktisch sind hier vor allem die Links, anhand derer Sie das Ergebnis der Suche gleich noch einmal überprüfen.

Parallel zur Ausgabe in eine Datei erfolgt eine Standardausgabe im Terminal. Soll Linkchecker gänzlich im Hintergrund werkeln, empfiehlt sich die Verwendung der Option -q: Sie unterdrückt die Ausgabe im Terminal. Einige Ausgabeformate wie gml benötigen zusätzlich die Option --verbose, da andernfalls die erzeugten Graphen Lücken enthalten. Linkchecker bezieht auf diese Weise Informationen über funktionierende Links in den Graphen mit ein.

Abbildung 3: Äußerst praktisch ist die Ausgabe des Ergebnisses in einem HTML-Dokument: Die Links in der HTML-Ausgabe nutzen Sie gleich auch zum Prüfen des Ergebnisses.

Tabelle 1: Ausgabeformate

Schlüsselwort

Bedeutung

text Standard-Textausgabe als flacher Text
html Ausgabe als HTML-Code, der auch gleich Links auf die referenzierten Seiten enthält
csv Ausgabe als komma-separierter Text, mit einer URL pro Zeile.
gml Ausgabe als Graph im GML-Format [6]
dot Ausgabe als Graph im .dot-Format [7]
gxml Ausgabe im GraphXML-Format [4]. Anzeigeprogramme gibt es u.a. hier [5]
xml Maschinenlesbar: Die Ausgabe im XML-Format
sql Ausgabe als INSERT-Anweisung in SQL
blacklist Mit dieser Option loggt Linkchecker ausschließlich Informationen über Fehler und schreibt diese in die Datei ~/.linkchecker/blacklist. Das ist sinnvoll für die Automatisierung mit Hilfe von Cron-Jobs.
none keine Ausgabe, sinnvoll für Skripte
Einem Freund empfehlen    Druckansicht Bookmark and Share
Kommentare

1177 Hits
Wertung: 0 Punkte (0 Stimmen)

Schlecht Gut

Infos zur Publikation

Infos zur Publikation

LinuxUser 06/2012

Aktuelle Ausgabe kaufen:

Heft bestellen Heft als PDF kaufen

LinuxUser erscheint monatlich und kostet in der Nomedia-Ausgabe EUR 5,50 und mit DVD EUR 8,50. Weitere Informationen zum Heft finden Sie auf der LinuxUser-Homepage.

Im LinuxUser-Probeabo erhalten Sie drei Ausgaben für 3 Euro. Das Jahresabo (ab EUR 56,10) können Sie im LNM-Shop bestellen.

Tipp der Woche

Adobe AIR
Adobe-AIR-Programme installieren und (manuell) starten
Tim Schürmann, 14.05.2012 13:09, 0 Kommentare

Es gibt sie noch: neue Anwendungen, die Adobes Integrated Runtime voraussetzen. Aktuellstes und vermutlich auch größtes Beispiel ist das Adventure Botanicula

Aktuelle Fragen

gibt es ein Kommandozeilen Tool, um ein X11-Fenster in ein Anderes einzubetten?
GoaSkin , 21.05.2012 16:44, 0 Antworten
Das XEmbed-Protokoll ist u.A. dazu gedacht, dass man eine X11-Anwendung in eine andere wie ein Wi...
Apache2, Options -Indexes geht nicht
no no, 12.05.2012 19:01, 8 Antworten
Habe in apache2.conf folgendes stehen: Options -Indexes ...
LInux auf Dell LS H500
Andreas Endresl, 09.05.2012 08:54, 2 Antworten
Habe einen alten Dell Latitude LS H500 nur mit ext. Floppy und CD es geht nur immer eines von den...
Datenwiederherstellung unter Ubuntu 12.04 mit "Simple Backup" nach Umzug von Linux Mint
Christian Lottmann, 07.05.2012 13:33, 0 Antworten
Vor dem Umzug auf Ubuntu 12.04 habe ich unter Linux MInt mit "Simple Backup" voll (15.4.2012) und...
DKMS für den propritären NVIDIA-Treiber
Commander Data, 26.04.2012 22:02, 2 Antworten
Hallo an die Gemeinde. Ich habe hier ein interessantes Stück openSuSE gefunden. http://forums.op...