Я хочу получить атрибут TITLE с помощью Java HTMLEditorKit?
это то, что я написал, но он будет возвращать «ноль» все время, и инспектор в затмении не очень помогает!
import java.io.FileReader;
import java.io.InputStream;
import java.io.InputStreamReader;
import java.io.Reader;
import java.net.URL;
import javax.swing.text.MutableAttributeSet;
import javax.swing.text.html.HTML;
import javax.swing.text.html.HTMLEditorKit;
import javax.swing.text.html.parser.ParserDelegator;
public class testHTML
{
public static void main(String args[]) throws Exception
{
Reader reader = new FileReader("C:\\wamp\\www\\t\\index.html");
new ParserDelegator().parse(reader, new LinkPage(), true);
}
}
class LinkPage extends HTMLEditorKit.ParserCallback
{
public void handleSimpleTag(HTML.Tag tag,
MutableAttributeSet attributes, int pos) {
if (tag == HTML.Tag.TITLE)
{
System.out.println(attributes.getAttribute(HTML.Attribute.TITLE));
}
}
public void handleStartTag(HTML.Tag t, MutableAttributeSet a, int pos)
{
// if (t == HTML.Tag.A)
// {
// //System.out.println("<BR>");
//
// }
// if(t == HTML.Tag.TITLE)
// {
// System.out.println(t.toString());
// System.out.println(t.TITLE);
// System.out.println();
// String text = (String)a.getAttribute(HTML.Attribute.TITLE);
// Object o = a.getAttribute(HTML.Attribute.TITLE);
// System.out.println(a);
// System.out.println(o);
// System.out.println(text);
// }
//
handleSimpleTag(t, a, pos);
}
}
и содержание HTML:
<html>
<head>
<title>test</title>
</head>
<body>
test
<a href="http://localhost/t/1.html">link1</a>
sdf
<a href="http://localhost/t/2.html">link2</a>
sdf
<a href="http://localhost/t/1.html">link3</a>
sdf
<a href="http://localhost/t/2.html">link3</a>
</body>
</html>
p.s: Мне известны XPATH, REGEX и любые другие сторонние компоненты для простого извлечения атрибутов HTML, но я также хочу научиться и сложному.