Maven 无法编译依赖于 rt 的类.jar

2022-09-03 01:12:59

我负责的CI服务器(Hudson)构建了Maven项目。上次提交后,构建失败:

[INFO] -------------------------------------------------------------
[ERROR] COMPILATION ERROR : 
[INFO] -------------------------------------------------------------
[ERROR] \hudson\jobs\path to my class\MyClass.java:[33,62] package com.sun.xml.internal.messaging.saaj.packaging.mime.util does not exist
[ERROR] \hudson\jobs\path to my class\MyClass.java:[75,5] cannot find symbol
        symbol  : class BASE64EncoderStream
        location: class |fullname of MyClass|
[ERROR] \hudson\jobs\path to my class\MyClass.java:[75,38] cannot find symbol
        symbol  : class BASE64EncoderStream
        location: class |fullname of MyClass|
[INFO] 3 errors

Required class (com.sun.xml.internal.messaging.saaj.packaging.mime.util.BASE64EncoderStream) 位于 rt.jar。

我尝试(按照 http://maven.apache.org/guides/introduction/introduction-to-dependency-mechanism.html#System_Dependencies 的说明)在项目的pom中添加系统依赖性.xml:

<dependency>
    <groupId>dummy</groupId>
    <artifactId>dummy</artifactId>
    <version>1</version>
    <scope>system</scope>
    <systemPath>${java.home}/lib/rt.jar</systemPath>
</dependency>

这无济于事。

最有趣的是,所有文件在我的同事的本地机器上编译得很好(他使用Eclipse内置编译器)。

在互联网上,我发现了同样的问题(链接:http://maven.40175.n5.nabble.com/Why-can-t-Maven-find-com-sun-xml-internal-messaging-saaj-util-ByteOutputStream-class-td107361.html)。最后的答案是,造成这种麻烦的原因是Oracle的Java编译器。

所以,我把Oracle的jdk改成了OpenJDK,但它没有帮助。

有人对如何解决这个问题有什么建议吗?


答案 1

需要指定和添加 rt.jar依赖项,否则编译器插件将静默地删除任何 -XD 标志:例如-XDignore.symbol.file<fork>true</fork>

    ...
    <dependency>
        <groupId>groupid</groupId>
        <artifactId>artifiactId</artifactId>
        <version>1.0</version>
        <scope>system</scope>
        <systemPath>${java.home}/lib/rt.jar</systemPath>
    </dependency>
</dependencies>

<build>
    <plugins>
        <plugin>
            <groupId>org.apache.maven.plugins</groupId>
            <artifactId>maven-compiler-plugin</artifactId>
            <version>3.3</version>
            <configuration>
                <source>1.7</source>
                <target>1.7</target>
                <compilerArgs>
                    <arg>-XDignore.symbol.file</arg>
                </compilerArgs>
                <fork>true</fork>
            </configuration>
            ...

答案 2

缺少的类似乎是 JRE 内部的(如其命名空间中所示),不应从代码中引用。它可能仅在特定平台或 JRE 版本上可用。

考虑用另一个Base64编码器类替换它,例如Apache Commmons编解码器项目中的一个。

Java 8 更新

Java 8 最终在 JDK 的公共部分引入了一个 Base64 类:java.util.Base64


推荐