让我们考虑这个 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,并在完成解析后将其传递过去。
或者在这种情况下我还能做些什么?
谢谢