我有一些使用 JAXB API 类的代码,这些类在 Java 6/7/8 中作为 JDK 的一部分提供。当我使用 Java 9 运行相同的代码时,在运行时出现错误,表明找不到 JAXB 类。
JAXB 类自 Java 6 起就作为 JDK 的一部分提供,那么为什么 Java 9 不再能找到这些类呢?
原文由 Andy Guibert 发布,翻译遵循 CC BY-SA 4.0 许可协议
我有一些使用 JAXB API 类的代码,这些类在 Java 6/7/8 中作为 JDK 的一部分提供。当我使用 Java 9 运行相同的代码时,在运行时出现错误,表明找不到 JAXB 类。
JAXB 类自 Java 6 起就作为 JDK 的一部分提供,那么为什么 Java 9 不再能找到这些类呢?
原文由 Andy Guibert 发布,翻译遵循 CC BY-SA 4.0 许可协议
15 回答8.4k 阅读
8 回答6.2k 阅读
1 回答4k 阅读✓ 已解决
3 回答6k 阅读
3 回答2.2k 阅读✓ 已解决
2 回答3.1k 阅读
2 回答3.8k 阅读
2 回答2.7k 阅读✓ 已解决
2 回答1.8k 阅读✓ 已解决
2 回答802 阅读✓ 已解决
1 回答1.8k 阅读
2 回答1.9k 阅读✓ 已解决
JAXB API 被视为 Java EE API,因此不再包含在 Java SE 9 中的默认类路径中。在 Java 11 中,它们已从 JDK 中完全删除。
Java 9 引入了模块的概念,默认情况下,
java.se
聚合模块在类路径(或者更确切地说,模块路径)上可用。顾名思义,java.se
聚合模块 不 包括传统上与 Java 6/7/8 捆绑的 Java EE API。幸运的是,JDK 6/7/8 中提供的这些 Java EE API 仍然在 JDK 中,但它们只是默认不在类路径中。以下模块中提供了额外的 Java EE API:
快速而肮脏的解决方案:(仅限JDK 9/10)
要使 JAXB API 在运行时可用,请指定以下命令行选项:
--add-modules java.xml.bind
但我仍然需要它才能与 Java 8 一起使用!!!
如果您尝试使用较旧的 JDK 指定
--add-modules
,它将崩溃,因为它是一个无法识别的选项。我建议以下两种选择之一:JDK_JAVA_OPTIONS
环境变量设置任何仅限 Java 9+ 的选项。此环境变量由java
Java 9+ 的启动器 自动读取。-XX:+IgnoreUnrecognizedVMOptions
以使 JVM 静默忽略无法识别的选项,而不是炸毁。但要小心! JVM 将不再为您验证您使用的任何其他命令行参数。此选项适用于 Oracle/OpenJDK 以及 IBM JDK(从 JDK 8sr4 开始)。替代快速解决方案:(仅限 JDK 9/10)
请注意,您可以通过指定
--add-modules java.se.ee
选项使上述所有 Java EE 模块在运行时可用。java.se.ee
模块是一个聚合模块,包括java.se.ee
以及上述 Java EE API 模块。请注意,这 在 Java 11 上不起作用, 因为java.se.ee
在 Java 11 中已被删除。适当的长期解决方案:(JDK 9 及更高版本)
上面列出的 Java EE API 模块都标记为
@Deprecated(forRemoval=true)
因为它们 计划 在 Java 11 中删除。因此--add-module
方法将不再适用于 Java 11 开箱即用。在 Java 11 及更高版本中,您需要做的是在类路径或模块路径中包含您自己的 Java EE API 副本。例如,您可以将 JAX-B API 添加为 Maven 依赖项,如下所示:
有关 JAXB 的更多详细信息,请参阅 JAXB 参考实现页面。
有关 Java 模块化的完整详细信息,请参阅 JEP 261:模块系统
截至 2022 年 7 月,bind-api 和 jaxb-runtime 的最新版本为 4.0.0。所以你也可以使用
…在那些依赖条款中。但是,如果您这样做,包名称已从
javax.xml.bind...
更改为jakarta.xml.bind...
。您将需要修改源代码以使用这些更高版本的 JAR。对于 Gradle 或 Android Studio 开发人员:(JDK 9 及更高版本)
将以下依赖项添加到您的
build.gradle
文件中: