Ant自动编译Java project时无法找到rt.jar的处理方法

Posted 要千

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Ant自动编译Java project时无法找到rt.jar的处理方法相关的知识,希望对你有一定的参考价值。

最近在使用Ant自动化编译打包一个Java项目,执行时总是报有class找不到:

    [javac] Compiling 46 source files to /A/B/C/D/build/staging/bin
    [javac] .../ChangePassWordTool.java:5: 
package com.sun.org.apache.xml.internal.security.utils does not exist
    [javac] import com.sun.org.apache.xml.internal.security.utils.Base64;
    [javac]                                                      ^
    [javac] .../ChangePassWordTool.java:39: cannot find symbol
    [javac] symbol  : variable Base64
    [javac] location: class com.xxx.ChangePassWordTool
    [javac]             passWord = Base64.encode(passWord.getBytes()); 
    [javac]                        ^
    [javac] 2 errors

由于在eclipse中使用ant插件编译打包该项目没有问题,纳闷为啥出现该异常。

首先定位该类:com.sun.org.apache.xml.internal.security.utils.Base64,发现是在jre/rt.jar中,因此第一步怀疑是ant的配置文件有问题,将build.xml中的文件调整如下:

[html]  view plain  copy  
  1. <project default="prod" basedir=".">  
  2.           
  3.     ...  
  4.     <property environment="env" />  
  5.     <property name="java.jre.lib.dir" value="$env.JAVA_HOME/jre/lib" />  
  6.       
  7.     <!-- classpath used for javac -->  
  8.     <path id="classpath">  
  9.         <fileset dir="lib" includes="*.jar"/>           
  10.         <fileset dir="$java.jre.lib.dir">  
  11.             <include name="*.jar" />  
  12.         </fileset>      
  13.     </path>  
  14.       
  15.     ...  
  16.     <target name="compile" depends="init">  
  17.         <javac  
  18.             srcdir="src"  
  19.             destdir="$staging/bin"  
  20.             encoding="UTF-8"  
  21.             source="1.6"  
  22.             target="1.6"  
  23.             nowarn="on"  
  24.             debug="on"  
  25.             optimize="on"  
  26.             includeantruntime="false">                         
  27.             <classpath refid="classpath" />                 
  28.         </javac>  
  29.     </target>  
  30.   
  31. </project>  

但是调整之后,编译打包还是报上述错误, 后查询 资料 发现, 是由于javac编译代码的行为所致。

javac在编译代码时,当他尝试从rt.jar中找寻对应的类文件时,他会默认从对应的符号表文件ct.sym (同样在jre/lib/下)中查找该类是否存在,由于ct.sym中有意或无意的遗失了部分rt.jar中的类,包括我使用的com.sun.org.apache.xml.internal.security.utils.Base64,因此导致编译报错。


解决方法就是通知javac编译器,在编译代码时,忽略该符号表ct.sym, 直接查找rt.jar,通过给javac传入对应的参数完成:-XDignore.symbol.file

在配置文件中即为:

[html]  view plain  copy  
  1. <javac  
  2.     srcdir="src"  
  3.     destdir="$staging/bin"  
  4.     encoding="UTF-8"  
  5.     source="1.6"  
  6.     target="1.6"  
  7.     nowarn="on"  
  8.     debug="on"  
  9.     optimize="on"  
  10.     includeantruntime="false">  
  11.                 <compilerarg value="-XDignore.symbol.file"/>            
  12.     <classpath refid="classpath" />                 
  13. </javac>  


编译成功

以上是关于Ant自动编译Java project时无法找到rt.jar的处理方法的主要内容,如果未能解决你的问题,请参考以下文章

android project clean后无法生成R.java文件,因为程序中有编译错误,但是错误都是因为R文件资源未找到TT?

在 NetBeans 中编译 Maven 项目时 Ant 无法找到环境变量

ant 使用指南---java模块化编译

运行ant时“无法找到tools.jar” [重复]

带有 maven-antrun-plugin 的 Maven Ant BuildException ...无法找到 javac 编译器

编译“ant”构建时出错