我正在升级我们的应用程序以使用Java 9(婴儿步骤......一旦我们得到9工作,我们将跳到10)。我们遇到的一个问题是,在运行时,我们得到一个模块异常,我似乎无法弄清楚发生了什么。我不可否认是模块的新手,并且已经阅读了关于这个主题的所有内容,但我猜这可能是一个简单的答案。
要调用的运行时是
java --add-modules java.se,java.se.ee -cp mainjar.jar:jaxb-api.jar:jaxb-impl.jar:jaxb-core.jar foo.bar.Launch
尝试读取XML数据时发生异常:
WARN:09:22:10.777 [main] (Preference:969) - Failed to unmarshal preference value for key [launch.maxMemory]: javax.xml.bind.JAXBException: Package java.lang with JAXB class java.lang.Integer defined in a module java.base must be open to at least java.xml.bind module.
javax.xml.bind.JAXBException: Package java.lang with JAXB class java.lang.Integer defined in a module java.base must be open to at least java.xml.bind module.
at java.xml.bind@9.0.4/javax.xml.bind.ModuleUtil.delegateAddOpensToImplModule(Unknown Source)
at java.xml.bind@9.0.4/javax.xml.bind.ContextFinder.newInstance(Unknown Source)
at java.xml.bind@9.0.4/javax.xml.bind.ContextFinder.newInstance(Unknown Source)
at java.xml.bind@9.0.4/javax.xml.bind.ContextFinder.find(Unknown Source)
at java.xml.bind@9.0.4/javax.xml.bind.JAXBContext.newInstance(Unknown Source)
at java.xml.bind@9.0.4/javax.xml.bind.JAXBContext.newInstance(Unknown Source)
答案 0 :(得分:4)
我遇到了类似的问题。
我在 com.redeg
中有我的实体,在 com.redeg.xml
中有用于处理 XML 的类,并在 opens com.redeg.xml to java.xml.bind
文件中添加了一行 module-info.java
有帮助。
module-info.java
:
module com.redeg {
exports com.redeg;
requires java.xml.bind;
opens com.redeg to java.xml.bind;
opens com.redeg.xml to java.xml.bind;
}