HTML oder nicht? Das ist hier die Frage.

Status
Nicht offen für weitere Antworten.
W

Werner

Gast
Hallo,

ich schreibe gerade an einem WebCrawler (bin kein Anfänger) und hänge an folgendem Problem:

Ich lese über HttpURLConnection per URL.openConnection() den Inhalt einer URl ein und parse
dann die Webseite. Soweit ist alles trivial. Ihr wisst bestimmt schon was kommt :roll:
Da ich mit URI- und URL-Objekten arbeite, um z.B. die Relativen- in Ablotute-URLs aufzulösen,
bin ich darauf angewiesen, dass der Parser auch wirklich eine HTML-Seite als "Futter" bekommt.

Im WEB ist es wohl so, dass bei einem Content-Type text/html etc in 98% der Fällen
eine HTML Seite zu erwarten ist. Nur, was ist wenn der Webserver ein z.B. reines
Perl-Script in Textform zurück-liefert. Das bekommt dann mein Parser als
vermeintliche HTML-Datei und quittiert mir das zurecht mit einer Exception bzw.
mit fehlerhaften Ergebnissen. Kurz und gut, hier meine Frage:

Wie kann ich feststellen, um welches Datei-Format es sich von der von mir über einen URL
angeforderte Webresource wirklich handelt?
???:L Also woran kann ich eine HTML-Seite erkennen.
Z.B: kann man ja schlecht eine PDF durch einen HTML-Parser jagen.... lol

Vielen Dank für Eure Hilfe!!


PS:
Bitte kommt mir aber nicht mit: "Suche doch nach "<html..." oder "<!DOCTYPE HTML " etc..." Leider sieht die
Wirklichkeit erschreckend aus und es fällt mir ein Zitat von Google ein: "Webmaster sind nicht in der
Lage syntaktisch korrektes HTML zu schreiben
" Sicher, 90% maches es vielleicht richtig, aber was ist mit
den restlichen 10%? Die muss ein Parser auch verdauen und darin liegt das wirkliche Problem.
 

Wildcard

Top Contributor
Zunächst mal der Content-Type:
http://java.sun.com/javase/6/docs/api/java/net/URLConnection.html#getContentType()
Wenn der text/html liefert und dein Parser auf die Nase fliegt ist entweder der Parser falsch, oder es ist kein html.
"Webmaster sind nicht in der
Lage syntaktisch korrektes HTML zu schreiben" Sicher, 90% maches es vielleicht richtig, aber was ist mit
den restlichen 10%
Die Annahme das 90% der Webseiten valides HTML darstellen ist völlig illusorisch. Schick einfach mal eine beliebige Seite durch den W3 Validator.
 
W

Werner

Gast
Hi,

"Die Annahme das 90% der Webseiten valides HTML darstellen ist völlig illusorisch. Schick einfach mal eine beliebige Seite durch den W3 Validator."

Ja, da hast Du wohl Recht. Es sieht NOCH schlimmer aus. :?
Eigentlich darf man keinem Ergebnis trauen. Aber gibt es den nun
so eine Art HTML-Validator, der mir sagt, ob es sich um eine HTML-Seite
handelt oder nicht???
Und ich meine jetzt nicht so einen Syntax-Validator
wie den vom W3C.

Gruß, Werner
 

Wildcard

Top Contributor
Werner hat gesagt.:
Aber gibt es den nun
so eine Art HTML-Validator, der mir sagt, ob es sich um eine HTML-Seite
handelt oder nicht???
Was soll der machen? Schätzen?
Geh davon aus das es sich um html handelt und wenn dein Parser auf die Nase fliegt, weißt du das etwas nicht stimmt.
 
Status
Nicht offen für weitere Antworten.
Ähnliche Java Themen
  Titel Forum Antworten Datum
W HTML Code, Umlaute werden nicht richtig dargestellt Java Basics - Anfänger-Themen 7
D Interpreter-Fehler JavaApplet läuft in der IDE aber nicht im HTML Dokument Java Basics - Anfänger-Themen 9
Developer_X HTML Datei nicht von Java Lesbar Java Basics - Anfänger-Themen 8
hdi HTML code geht nicht bei JEditorPane Java Basics - Anfänger-Themen 5
W Javadoc HTML erzeugen mit allen dependency Java Basics - Anfänger-Themen 11
M html-seite drucken (gerendert) Java Basics - Anfänger-Themen 3
I HTML Code säubern Java Basics - Anfänger-Themen 4
B HTML File einlesen inkl. Bilder? Java Basics - Anfänger-Themen 2
B HTML Datei einlesen und HTML Code in String wandeln Java Basics - Anfänger-Themen 19
B HTML Code in XML speichern Java Basics - Anfänger-Themen 3
B HTML Code / Seite auslesen und JAVA Objekte erstellen Java Basics - Anfänger-Themen 12
K Erstes kleines Spieleprojekt - Java GUI in HTML einbinden Java Basics - Anfänger-Themen 3
B String nach HTML formatieren Java Basics - Anfänger-Themen 9
S HTML-Quelltext hinter HTTPS Java Basics - Anfänger-Themen 1
J Input/Output Input Buttons Html mit JSP Java Basics - Anfänger-Themen 3
E HTML in Java einbinden oder JavaScript? Java Basics - Anfänger-Themen 5
D Mit Java HTML bzw Javascript auslesen Java Basics - Anfänger-Themen 1
G Servlet - externe HTML (URL) auslesen Java Basics - Anfänger-Themen 1
S Text aus einer HTML Datei auslesen Java Basics - Anfänger-Themen 1
krgewb Input/Output Umlaute in generierter HTML-Datei Java Basics - Anfänger-Themen 7
N Status-Log - HTML Java Basics - Anfänger-Themen 12
C Methoden Welche JSoup Methoden Und Parameter für diese HTML Tags Java Basics - Anfänger-Themen 4
I Meta Tags vergleichen mit Html Vorgabe Java Basics - Anfänger-Themen 8
B HTML Code drucken Java Basics - Anfänger-Themen 4
D HTML Manipulation Navigation Java Basics - Anfänger-Themen 1
Z Html Element aus der Webseite auslesen Java Basics - Anfänger-Themen 1
D Erste Schritte HTML aus JEditorPane drucken Java Basics - Anfänger-Themen 5
M Fragen zum Auslesen von HTML Seiten Java Basics - Anfänger-Themen 5
M Java und Html Java Basics - Anfänger-Themen 4
I HTML Code in Bild (transparent) konvertieren Java Basics - Anfänger-Themen 0
I Watermark erstellen mit HTML in Bild? Java Basics - Anfänger-Themen 7
T Ausgabe in HTML :( Java Basics - Anfänger-Themen 19
F HTML Datei in .jar speichern und abändern Java Basics - Anfänger-Themen 2
S mit Java HTML Button drücken "lassen" Java Basics - Anfänger-Themen 8
M Erste Schritte Java Applet - HTML Seiten auslesen und in Access Datenbank schreiben? Java Basics - Anfänger-Themen 15
T HTML-Inputbox ansteuern Java Basics - Anfänger-Themen 4
I HTML Tabelle nur so lange erzeugen bis Höhe erreicht Java Basics - Anfänger-Themen 9
I HTML in String wandeln? Java Basics - Anfänger-Themen 1
D javacode durch Html ausfuehren Java Basics - Anfänger-Themen 13
C Html in einem JEditorPane anzeigen Java Basics - Anfänger-Themen 2
I jar-Datei in HTML einbinden Java Basics - Anfänger-Themen 6
O HTML -> BBCode Parser? Java Basics - Anfänger-Themen 3
O Methode in andere Klasse verlegt, "auslesen" einer HTML Seite verschnellert - Problem. Java Basics - Anfänger-Themen 4
V Umlaute beim Parsen einer HTML Seite Java Basics - Anfänger-Themen 4
C Java Applet in html. Pong - old school Spiel Java Basics - Anfänger-Themen 10
J Methode um eine HTML-Datei zu öffnen Java Basics - Anfänger-Themen 10
H Schnell HTML-Tags finden Java Basics - Anfänger-Themen 5
H Welcher Html-Parser? Java Basics - Anfänger-Themen 8
G Probleme beim HTML auslesen Java Basics - Anfänger-Themen 6
J Html zugriff - POST Request/Response Java Basics - Anfänger-Themen 4
A HTML-Code auslesen und mit einem Wert in der property-Datei vergleichen Java Basics - Anfänger-Themen 2
Z Input/Output HTML-Seite einlesen Java Basics - Anfänger-Themen 4
H Interface JTextPane html formatiert kopieren Java Basics - Anfänger-Themen 2
L Applet soll Html-File öffnen Java Basics - Anfänger-Themen 2
L NetBeans Applet in html Java Basics - Anfänger-Themen 4
H Java Server/Client, HTML Seite anzeigen Java Basics - Anfänger-Themen 2
D Wie den HTML-Teil des Chat Tutorials aus dem FAQ-Bereich starten? Java Basics - Anfänger-Themen 5
C Link wie bei HTML Java Basics - Anfänger-Themen 7
F Methoden replaceAll (regex) HTML Java Basics - Anfänger-Themen 3
M Mit Java eine HTML-Seite speichern Java Basics - Anfänger-Themen 11
C Java in HTML einbinden Java Basics - Anfänger-Themen 2
N Website HTML mit JavaScript abrufen Java Basics - Anfänger-Themen 9
R JSON - Ausgabe als HTML mit gson Java Basics - Anfänger-Themen 6
R Suche Regex Ausdruck für HTML Java Basics - Anfänger-Themen 11
A JEditorPane + html -> java.io.IOException: invalid url Java Basics - Anfänger-Themen 4
S Lightbox Script vs. Taco HTML Script Java Basics - Anfänger-Themen 4
R Pattern bzw. Regex HTML-Code Java Basics - Anfänger-Themen 10
S String mit ASCII/HTML Zeichen darstellen Java Basics - Anfänger-Themen 10
S HTML Regularer Expression Java Basics - Anfänger-Themen 20
S regulärer Ausdruck HTML Java Basics - Anfänger-Themen 5
D Html Formular auswerten Java Basics - Anfänger-Themen 8
P Java Object das eine HTML Datei repräsentiert Java Basics - Anfänger-Themen 19
eLogic Einlesen von HTML-Source Java Basics - Anfänger-Themen 6
turmaline Ein regulärer Ausdruck für HTML-Sonderzeichen Java Basics - Anfänger-Themen 3
H html-Text mit Formatierung in String speichern Java Basics - Anfänger-Themen 4
S Java und HTML- Drop Down- Mehrfachauswahl Java Basics - Anfänger-Themen 3
A execute jar from html Java Basics - Anfänger-Themen 6
StupidAttack Html Code durchsuchen Java Basics - Anfänger-Themen 2
T Servlet HTML-Formular Java Basics - Anfänger-Themen 9
TheKing HTML Formular mit Java ausfüllen und absenden Java Basics - Anfänger-Themen 9
P HTML <input> Feld in einem JLabel auslesen Java Basics - Anfänger-Themen 4
C einfacher Link zu *.html Datei möglich? Java Basics - Anfänger-Themen 4
V javascript und HTML: hoch 2 Java Basics - Anfänger-Themen 2
M index.html fehlt Java Basics - Anfänger-Themen 12
3 Eine HTML Datei in eine Java Datei umschreiben Java Basics - Anfänger-Themen 23
Weltall 7 Applet in HTML einbinden Java Basics - Anfänger-Themen 3
A Java in Html einbinden Java Basics - Anfänger-Themen 2
M Frage zum Aufruf eines Applets aus einer HTML - Datei Java Basics - Anfänger-Themen 3
sylo Auf HTML-Dateien in einer Jar zugreifen Java Basics - Anfänger-Themen 9
D HTML Text von jButton disablen Java Basics - Anfänger-Themen 2
I CSV Datei auf HTML Seite hochladen und in DB laden Java Basics - Anfänger-Themen 9
K html to pdf Java Basics - Anfänger-Themen 6
D String aus Html (sonderfall) Java Basics - Anfänger-Themen 9
F html editor Java Basics - Anfänger-Themen 5
A html parser Java Basics - Anfänger-Themen 5
G HTML Seite generieren Java Basics - Anfänger-Themen 2
S Text aus HTML Datei in TXT Datei Java Basics - Anfänger-Themen 19
U HTML-String zusammenbauen Java Basics - Anfänger-Themen 4
P Datentypen HTML Dokument speichern (Netbeans) Java Basics - Anfänger-Themen 10
S kreative Schlaue funktion für optionsfeld (html) gesucht... Java Basics - Anfänger-Themen 4

Ähnliche Java Themen

Neue Themen


Oben