だから私がやろうとしていることはとても簡単です。スクリプトタグのHTMLドキュメントを解析し、ParserDelegatorを使用し、ParserCallbackを使用してスクリプトタグを吐き出します。しかし、このプログラムを実行すると、何も実行されません。コールバックが呼び出されることはありません。私のhtmlファイルパスは正しく、スクリプトタグが含まれています。正しくフォーマットされています。
import java.io.*;
import javax.swing.text.html.parser.ParserDelegator;
import javax.swing.text.html.HTMLEditorKit;
import javax.swing.text.html.HTML;
import javax.swing.text.SimpleAttributeSet;
import java.util.Enumeration;
public class JSFinder {
//static ParserDelegator pd;
public JSFinder () {
//pd = new ParserDelegator();
}
public static void main(String args[]) {
try {
HTMLEditorKit.ParserCallback callback = new ScriptTagCallBack();
new ParserDelegator().parse(new InputStreamReader(new FileInputStream(new File ("<path-to-html>"))), callback, false);
}
catch (Exception e) {
e.printStackTrace();
}
}
}
class ScriptTagCallBack extends HTMLEditorKit.ParserCallback {
public ScriptTagCallBack() {
super();
}
public void handleStartTag(HTML.Tag t, SimpleAttributeSet a, int pos) {
if(t == HTML.Tag.SCRIPT) {
System.out.println("Found a script tag");
System.out.println(a);
}
else {
System.out.println("Not a script tag");
}
}
public void handleEndTag(HTML.Tag t, SimpleAttributeSet a, int pos) {
if(t == HTML.Tag.SCRIPT) {
System.out.println("Found a script tag");
System.out.println(a);
}
else {
System.out.println("Not a script tag");
}
}
}
私が間違っていることについて何か考えはありますか?私は例(この例のように:http ://www.java2s.com/Tutorial/Java/0320__Network/HTMLparserbasedonHTMLEditorKitParserCallback.htm )を見てきましたが、基本的に同じことをしています(おそらくすべてをオーバーライドしていないことを除いて) ParserCallbackのメソッドであり、URLの代わりにファイルパスを使用しています)。前もって感謝します。