JAXB API 被视为 Java EE API,因此不再包含在 Java SE 9 中的默认类路径中。在 Java 11 中,它们已从 JDK 中完全删除。
Java 9 引入了模块的概念,默认情况下,java.se
聚合模块在类路径(或者更确切地说,模块路径)上可用。顾名思义,java.se
聚合模块的作用not包括传统上与 Java 6/7/8 捆绑在一起的 Java EE API。
幸运的是,JDK 6/7/8 中提供的这些 Java EE API 仍然在 JDK 中,但默认情况下它们不在类路径中。以下模块提供了额外的 Java EE API:
java.activation
java.corba
java.transaction
java.xml.bind << This one contains the JAXB APIs
java.xml.ws
java.xml.ws.annotation
快速但肮脏的解决方案:(仅限 JDK 9/10)
要使 JAXB API 在运行时可用,请指定以下命令行选项:
--add-modules java.xml.bind
但我仍然需要这个才能与 Java 8 一起工作!
如果您尝试指定--add-modules
使用较旧的 JDK,它会崩溃,因为它是一个无法识别的选项。我建议选择以下两个选项之一:
- 您可以使用以下命令设置任何仅限 Java 9+ 的选项
JDK_JAVA_OPTIONS
环境变量。这个环境变量是自动读取 by the java
Java 9+ 的启动器。
- 您可以添加
-XX:+IgnoreUnrecognizedVMOptions
使 JVM 默默地忽略无法识别的选项,而不是崩溃。但要小心! JVM 将不再为您验证您使用的任何其他命令行参数。此选项适用于 Oracle/OpenJDK 以及 IBM JDK(从 JDK 8sr4 开始)。
替代快速解决方案:(仅限 JDK 9/10)
请注意,您可以通过指定以下方式使上述所有 Java EE 模块在运行时可用:--add-modules java.se.ee
选项。这java.se.ee
module 是一个聚合模块,包括java.se.ee
以及上面的 Java EE API 模块。注意,这个不适用于 Java 11因为java.se.ee
在 Java 11 中被删除。
正确的长期解决方案:(JDK 9 及更高版本)
上面列出的 Java EE API 模块均已标记@Deprecated(forRemoval=true)
因为他们是计划拆除 in Java 11。所以--add-module
该方法在 Java 11 中不再适用。
在 Java 11 及更高版本中,您需要做的是将您自己的 Java EE API 副本包含在类路径或模块路径中。例如,您可以将 JAX-B API 添加为 Maven 依赖项,如下所示:
<!-- API, java.xml.bind module -->
<dependency>
<groupId>jakarta.xml.bind</groupId>
<artifactId>jakarta.xml.bind-api</artifactId>
<version>2.3.2</version>
</dependency>
<!-- Runtime, com.sun.xml.bind module -->
<dependency>
<groupId>org.glassfish.jaxb</groupId>
<artifactId>jaxb-runtime</artifactId>
<version>2.3.2</version>
</dependency>
See the JAXB 参考实现页面有关 JAXB 的更多详细信息。
有关 Java 模块化的完整详细信息,请参阅JEP 261:模块系统
截至 2022 年 7 月,bind-api 和 jaxb-runtime 的最新版本为 4.0.0。所以你也可以使用
<version>4.0.0</version>
...在这些依赖条款中。但如果你这样做,包名称就会从javax.xml.bind...
to jakarta.xml.bind...
。您将需要修改源代码才能使用这些较新版本的 JAR。
对于 Gradle 或 Android Studio 开发人员:(JDK 9 及更高版本)
将以下依赖项添加到您的build.gradle
file:
dependencies {
// JAX-B dependencies for JDK 9+
implementation "jakarta.xml.bind:jakarta.xml.bind-api:2.3.2"
implementation "org.glassfish.jaxb:jaxb-runtime:2.3.2"
}