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

时间:2012-10-29 12:48:18

标签: java maven continuous-integration

我负责的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

必需的类(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,但它没有帮助。

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

2 个答案:

答案 0 :(得分:13)

需要指定if并添加rt.jar依赖项和-XDignore.symbol.file,因为编译器插件将以静默方式删除任何-XD标志:例如。

<fork>true</fork>

答案 1 :(得分:7)

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

考虑将其替换为另一个Base64编码器类,例如一个来自Apache Commmons Codec project

Java 8更新

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