1

让我们考虑这个 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,并在完成解析后将其传递过去。

或者在这种情况下我还能做些什么?

谢谢

4

1 回答 1

4

或者在这种情况下我还能做些什么?

是的 - 永远不要这样做:

catch(Exception e){}

这不是 JDOM 或属性的问题,而是一般异常处理的问题。

您可能会得到一个NullPointerException,因为 XML 文件没有正确解析,所以该document字段是null. 但是因为您捕获并忽略了异常,所以您不会收到有意义的错误消息。

将你当前拥有的所有代码移到 catch 块之后,在 try/catch 块内,你会得到一个更有用的错误报告。

于 2011-08-04T12:08:31.157 回答