NoClassDefFoundError: org/w3c/dom/ls/DocumentLS with com.sun.msv.generator.Driver

问题描述

(编辑:看问题的最短直接陈述的结尾)

我正在尝试从 https://github.com/xmlark/msv 运行 msv-generator。 我下载了这个源代码,构建了它并将以下 jars 放在一个文件夹中(跳过了 javadocs,sources,tests):

ant.jar
crimson.jar
isorelax.jar
jdom.jar
junit.jar
maven-repository-importer.jar
msv-core-2017.2-SNAPSHOT.jar
msv-generator-2017.2-SNAPSHOT.jar
msv-rngconverter-2017.2-SNAPSHOT.jar
original-msv-rngconverter-2017.2-SNAPSHOT.jar
relaxngDatatype.jar
resolver.jar
saxon.jar
servlet.jar
xalan.jar
xercesImpl.jar
xmlParserAPIs.jar
xsdlib-2017.2-SNAPSHOT.jar

当我尝试运行它时出现此错误

java -cp "c:/prog/msv/*" com.sun.msv.generator.Driver schema.rng
parsing a grammar: schema.rng
generating document #1
Exception in thread "main" java.lang.NoClassDefFoundError: org/w3c/dom/ls/DocumentLS

这个类存在于 jars 中:

unzip -l xercesImpl.jar |grep DocumentLS
      329  11-11-2002 17:20   org/w3c/dom/ls/DocumentLS.class

但我的 java 似乎在一个不在提供的 jar 中的模块中寻找 org.w3c.dom

java -version
java version "13.0.2" 2020-01-14
Java(TM) SE Runtime Environment (build 13.0.2+8)
Java HotSpot(TM) 64-Bit Server VM (build 13.0.2+8,mixed mode,sharing)

java  -verbose:class -cp "c:/prog/msv/*" com.sun.msv.generator.Driver schema.rng|grep org.w3c.dom
parsing a grammar: schema.rng
[1.249s][info][class,load] org.w3c.dom.Node source: jrt:/java.xml
generating document #1
[2.470s][info][class,load] org.w3c.dom.Document source: jrt:/java.xml
[2.481s][info][class,load] org.w3c.dom.CharacterData source: jrt:/java.xml

我认为它是 jdk.xml.dom 模块,但它不提供 org.w3c.dom.ls

java --describe-module jdk.xml.dom
jdk.xml.dom@13.0.2
exports org.w3c.dom.css
exports org.w3c.dom.html
exports org.w3c.dom.stylesheets
exports org.w3c.dom.xpath
requires java.base mandated
requires java.xml transitive

显式添加模块没有区别:

java --add-modules jdk.xml.dom -cp "c:/prog/msv/*" com.sun.msv.generator.Driver schema.rng
parsing a grammar: schema.rng
generating document #1
Exception in thread "main" java.lang.NoClassDefFoundError: org/w3c/dom/ls/DocumentLS

https://stackoverflow.com/a/5756989/285364 描述了 java.lang.classNotFoundExceptionjava.lang.NoClassDefFoundError间的区别。我得到的是后者,这可能意味着类初始值设定项中存在错误。所以我尝试直接加载:

java -cp c:/prog/msv/xercesImpl.jar org.w3c.dom.ls.DocumentLS
Error: Could not find or load main class org.w3c.dom.ls.DocumentLS
Caused by: java.lang.classNotFoundException: org.w3c.dom.ls.DocumentLS

现在我很难过,因为那个类在那个罐子里:

unzip -l c:/prog/msv/xercesImpl.jar |grep DocumentLS
      329  11-11-2002 17:20   org/w3c/dom/ls/DocumentLS.class

那个类有什么问题?我用 jad 对它进行了反编译,它看起来还可以......除了它不是一个类而是一个接口?

// Decompiled by Jad v1.5.8g. copyright 2001 Pavel Kouznetsov.
// Jad home page: http://www.kpdus.com/jad.html
// Decompiler options: packimports(3) 

package org.w3c.dom.ls;

import org.w3c.dom.DOMException;
import org.w3c.dom.Node;

public interface DocumentLS
{

    public abstract boolean getAsync();

    public abstract void setAsync(boolean flag)
        throws DOMException;

    public abstract void abort();

    public abstract boolean load(String s);

    public abstract boolean loadXML(String s);

    public abstract String saveXML(Node node)
        throws DOMException;
}

解决方法

我从最新的 xerces 发行版 https://xerces.apache.org/xerces2-j/install.html 中获得了以下 jar,这解决了问题:

resolver.jar
serializer.jar
xercesImpl.jar
xml-apis.jar