示例WorldWind应用程序在启动时遇到AbstractMethodError

时间:2013-09-04 14:06:39

标签: java worldwind

我的任务是使用WorldWind API创建应用程序,为了熟悉API,我尝试运行“HelloWorldWind”示例应用程序。当我这样做时,我得到以下错误堆栈:

Exception in thread "main" java.lang.AbstractMethodError: javax.xml.parsers.DocumentBuilderFactory.setFeature(Ljava/lang/String;Z)V
    at gov.nasa.worldwind.util.WWXML.createDocumentBuilder(WWXML.java:61)
    at gov.nasa.worldwind.util.WWXML.openDocumentStream(WWXML.java:236)
    at gov.nasa.worldwind.util.WWXML.openDocumentStream(WWXML.java:223)
    at gov.nasa.worldwind.util.WWXML.openDocumentFile(WWXML.java:175)
    at gov.nasa.worldwind.util.WWXML.openDocument(WWXML.java:148)
    at gov.nasa.worldwind.Configuration.loadConfigDoc(Configuration.java:131)
    at gov.nasa.worldwind.Configuration.<init>(Configuration.java:108)
    at gov.nasa.worldwind.Configuration.<clinit>(Configuration.java:76)
    at gov.nasa.worldwindx.examples.HelloWorldWind.main(HelloWorldWind.java:

WWXML.createDocumentBuilder如下:

public static DocumentBuilder createDocumentBuilder(boolean isNamespaceAware)
{
    DocumentBuilderFactory docBuilderFactory = DocumentBuilderFactory.newInstance();
    docBuilderFactory.setNamespaceAware(isNamespaceAware);
    if (Configuration.getJavaVersion() >= 1.6)
    {
        try
        {
            docBuilderFactory.setFeature("http://apache.org/xml/features/nonvalidating/load-external-dtd",
                false);    // Not getting past here
        }
        catch (ParserConfigurationException e)
        {   // Note it and continue on. Some Java5 parsers don't support the feature.
            String message = Logging.getMessage("XML.NonvalidatingNotSupported");
            Logging.logger().finest(message);
        }
    }
    ...

Reading some stuff online,人们指责jogl,因为我在64位系统上运行,但是,我已经在构建路径中拥有必要的jar。 此外,在浏览器中尝试上面显示的URL会返回404页面,这使我认为可能是原因 URL只是格式化某些首选项的方法。由于我没有DocumentBuilderFactory.setFeature的来源,我无法看到那里有什么混乱。

我的问题实际上是jogl还是其他什么?

2 个答案:

答案 0 :(得分:12)

这是某种类路径问题。当JVM尝试调用抽象方法(不允许)时,抛出AbstractMethodErrorDocumentBuilderFactory.setFeature(String, boolean)是一个在JavaSE 5中添加到DocumentBuilderFactory的抽象方法,因此针对J2SE 1.4.2版本编译的实现将不具有该方法,并且在对它们调用setFeature(String, boolean)时会发生此错误。

您的类路径上可能有一个旧的XML库,它返回了DocumetnBuilderFactory.newInstance()的实例。问题可能不在于JOGL本身,它可能只是JOGL将旧的XML库作为依赖项引入。

答案 1 :(得分:1)

您需要转到WWXML类并替换:

docBuilderFactory.setFeature("http://apache.org/xml/features/nonvalidating/load-external-dtd",
                false);

使用:

docBuilderFactory.setNamespaceAware(true);

java上的完整方法是:

    public static DocumentBuilder createDocumentBuilder(boolean isNamespaceAware)
{
    DocumentBuilderFactory docBuilderFactory = DocumentBuilderFactory.newInstance();

    docBuilderFactory.setNamespaceAware(isNamespaceAware);

    if (Configuration.getJavaVersion() >= 1.6)
    {
        docBuilderFactory.setNamespaceAware(true);
    }

    try
    {
        return docBuilderFactory.newDocumentBuilder();
    }
    catch (ParserConfigurationException e)
    {
        String message = Logging.getMessage("XML.ParserConfigurationException");
        Logging.logger().finest(message);
        throw new WWRuntimeException(e);
    }
}