このxmlファイルを考えてみましょう:
<?xml version="1.0" encoding="UTF-8"?>
<root attribute="value">
<element>myElement</element>
</root>
JDOMを使用してファイルを解析し、ルート要素から属性名と値を抽出しようとしています。
これは私がこの目的のために狂ったコードです:
public static org.jdom.Document document;
public static org.jdom.Element root;
SAXBuilder sxb = new SAXBuilder();
try
{
document = sxb.build(new File("file.xml"));
root = document.getRootElement();
List myList = root.getAttributes();
Iterator x = myList.iterator();
while(x.hasNext())
{
Attribute myAttribute = (Attribute)x.next();
System.out.println("name : " + myAttribute.getName() + " & value : " + myAttribute.getValue());
}
}
catch(Exception e){
e.printStackTrace();
}
このxmlファイルではすべて正常に機能します。しかし、私がこのファイルを使用するとき:
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE rootElement PUBLIC "-//Project" "mydtd.dtd">
<root attribute="value">
<element>myElement</element>
</root>
私は得るException in thread "main" java.lang.NullPointerException
解析する前にxmlファイルからDOCTYPEを削除し、解析が終了した後にそれを貼り付ける必要があると思いますか。
または、この状況で私ができることが他にありますか?
ありがとう