问题描述
(编辑:看问题的最短直接陈述的结尾)
我正在尝试从 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.classNotFoundException
和 java.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