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

本文介绍了一个在使用Ant进行Java项目自动化编译过程中遇到的问题:编译器无法找到rt.jar中的某些类。文章详细解释了问题的原因,并提供了解决方案,即通过修改Ant的配置文件来告诉javac编译器忽略符号表文件,直接查找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中的文件调整如下:

<project default="prod" basedir=".">
        
	...
	<property environment="env" />
	<property name="java.jre.lib.dir" value="${env.JAVA_HOME}/jre/lib" />
	
	<!-- classpath used for javac -->
	<path id="classpath">
		<fileset dir="lib" includes="*.jar"/>			
		<fileset dir="${java.jre.lib.dir}">
		    <include name="*.jar" />
		</fileset>	
	</path>
	
	...
	<target name="compile" depends="init">
		<javac
			srcdir="src"
			destdir="${staging}/bin"
			encoding="UTF-8"
			source="1.6"
			target="1.6"
			nowarn="on"
			debug="on"
			optimize="on"
			includeantruntime="false">            			
			<classpath refid="classpath" />				
		</javac>
	</target>

</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

在配置文件中即为:

		<javac
			srcdir="src"
			destdir="${staging}/bin"
			encoding="UTF-8"
			source="1.6"
			target="1.6"
			nowarn="on"
			debug="on"
			optimize="on"
			includeantruntime="false">
            		<compilerarg value="-XDignore.symbol.file"/>			
			<classpath refid="classpath" />				
		</javac>


编译成功


Abnormal build process termination: "D:\IntelliJ IDEA 2023.1.3\jbr\bin\java.exe" -Xmx700m -Djava.awt.headless=true "-Djna.boot.library.path=D:\IntelliJ IDEA 2023.1.3/lib/jna/amd64" -Djna.nosys=true -Djna.noclasspath=true --add-opens jdk.compiler/com.sun.tools.javac.api=ALL-UNNAMED --add-opens jdk.compiler/com.sun.tools.javac.util=ALL-UNNAMED --add-opens jdk.compiler/com.sun.tools.javac.code=ALL-UNNAMED --add-opens jdk.compiler/com.sun.tools.javac.comp=ALL-UNNAMED --add-opens jdk.compiler/com.sun.tools.javac.file=ALL-UNNAMED --add-opens jdk.compiler/com.sun.tools.javac.main=ALL-UNNAMED --add-opens jdk.compiler/com.sun.tools.javac.model=ALL-UNNAMED --add-opens jdk.compiler/com.sun.tools.javac.parser=ALL-UNNAMED --add-opens jdk.compiler/com.sun.tools.javac.processing=ALL-UNNAMED --add-opens jdk.compiler/com.sun.tools.javac.tree=ALL-UNNAMED --add-opens jdk.compiler/com.sun.tools.javac.jvm=ALL-UNNAMED -Dpreload.project.path=E:/code/longi_scp/scp-longi-module -Dpreload.config.path=C:/Users/10729/AppData/Roaming/JetBrains/IntelliJIdea2023.1/options -Dexternal.project.config=C:\Users\10729\AppData\Local\JetBrains\IntelliJIdea2023.1\projects\scp-longi-module.6bf958e2\external_build_system -Dcompile.parallel=false -Drebuild.on.dependency.change=true -Didea.IntToIntBtree.page.size=32768 -Djdt.compiler.useSingleThread=true -Daether.connector.resumeDownloads=false -Dio.netty.initialSeedUniquifier=-6863215404097317678 -Dfile.encoding=GBK -Duser.language=zh -Duser.country=CN -Didea.paths.selector=IntelliJIdea2023.1 "-Didea.home.path=D:/IntelliJ IDEA 2023.1.3" -Didea.config.path=C:/Users/10729/AppData/Roaming/JetBrains/IntelliJIdea2023.1 -Didea.plugins.path=C:/Users/10729/AppData/Roaming/JetBrains/IntelliJIdea2023.1/plugins -Djps.log.dir=C:/Users/10729/AppData/Local/JetBrains/IntelliJIdea2023.1/log/build-log "-Djps.fallback.jdk.home=D:/IntelliJ IDEA 2023.1.3/jbr" -Djps.fallback.jdk.version=17.0.7 -Dio.netty.noUnsafe=true -Djava.io.tmpdir=C:/Users/10729/AppData/Local/JetBrains/IntelliJIdea2023.1/compile-server/scp-longi-module_89b87d38/_temp_ -Djps.backward.ref.index.builder=true -Djps.track.ap.dependencies=false -Dtmh.instrument.annotations=true -Dtmh.generate.line.numbers=true "-Djps.kotlin.home=D:\IntelliJ IDEA 2023.1.3\plugins\Kotlin\kotlinc" -Dkotlin.incremental.compilation=true -Dkotlin.incremental.compilation.js=true -Dkotlin.daemon.enabled -Dkotlin.daemon.client.alive.path=\"C:\Users\10729\AppData\Local\Temp\kotlin-idea-7682868474734210158-is-running\" -Dide.propagate.context=false -classpath "D:/IntelliJ IDEA 2023.1.3/plugins/java/lib/jps-launcher.jar" org.jetbrains.jps.cmdline.Launcher "D:/IntelliJ IDEA 2023.1.3/plugins/java/lib/jps-builders.jar;D:/IntelliJ IDEA 2023.1.3/plugins/java/lib/jps-builders-6.jar;D:/IntelliJ IDEA 2023.1.3/plugins/java/lib/jps-javac-extension.jar;D:/IntelliJ IDEA 2023.1.3/lib/util.jar;D:/IntelliJ IDEA 2023.1.3/lib/util-8.jar;D:/IntelliJ IDEA 2023.1.3/lib/util_rt.jar;D:/IntelliJ IDEA 2023.1.3/lib/annotations.jar;D:/IntelliJ IDEA 2023.1.3/lib/3rd-party-rt.jar;D:/IntelliJ IDEA 2023.1.3/lib/protobuf.jar;D:/IntelliJ IDEA 2023.1.3/lib/jps-model.jar;D:/IntelliJ IDEA 2023.1.3/plugins/java/lib/javac2.jar;D:/IntelliJ IDEA 2023.1.3/lib/forms_rt.jar;D:/IntelliJ IDEA 2023.1.3/plugins/java/lib/aether-dependency-resolver.jar;D:/IntelliJ IDEA 2023.1.3/lib/idea_rt.jar;D:/IntelliJ IDEA 2023.1.3/plugins/JavaEE/lib/jasper-v2-rt.jar;D:/IntelliJ IDEA 2023.1.3/plugins/Kotlin/lib/jps/kotlin-jps-plugin.jar;D:/IntelliJ IDEA 2023.1.3/lib/util.jar;D:/IntelliJ IDEA 2023.1.3/plugins/eclipse/lib/eclipse-jps.jar;D:/IntelliJ IDEA 2023.1.3/plugins/eclipse/lib/eclipse-common.jar;D:/IntelliJ IDEA 2023.1.3/plugins/ant/lib/ant-jps.jar;D:/IntelliJ IDEA 2023.1.3/plugins/JavaEE/lib/javaee-jps.jar;D:/IntelliJ IDEA 2023.1.3/plugins/uiDesigner/lib/jps/java-guiForms-jps.jar;D:/IntelliJ IDEA 2023.1.3/plugins/space/lib/space-java-jps.jar;D:/IntelliJ IDEA 2023.1.3/plugins/devkit/lib/devkit-jps.jar;D:/IntelliJ IDEA 2023.1.3/plugins/platform-langInjection/lib/java-langInjection-jps.jar;D:/IntelliJ IDEA 2023.1.3/plugins/javaFX/lib/javaFX-jps.jar;D:/IntelliJ IDEA 2023.1.3/plugins/javaFX/lib/javaFX-common.jar;D:/IntelliJ IDEA 2023.1.3/plugins/Groovy/lib/groovy-jps.jar;D:/IntelliJ IDEA 2023.1.3/plugins/Groovy/lib/groovy-constants-rt.jar;D:/IntelliJ IDEA 2023.1.3/plugins/maven/lib/maven-jps.jar;D:/IntelliJ IDEA 2023.1.3/plugins/gradle-java/lib/gradle-jps.jar;D:/IntelliJ IDEA 2023.1.3/plugins/JPA/lib/jps/javaee-jpa-jps.jar" org.jetbrains.jps.cmdline.BuildMain 127.0.0.1 50936 a62b4750-6999-4802-b6f9-8b630f13810a C:/Users/10729/AppData/Local/JetBrains/IntelliJIdea2023.1/compile-server OpenJDK 64-Bit Server VM warning: INFO: os::commit_memory(0x00000000d4400000, 526385152, 0) failed; error='页面文件太小,无法完成操作。' (DOS error/errno=1455) # # There is insufficient memory for the Java Runtime Environment to continue. # Native memory allocation (mmap) failed to map 526385152 bytes for G1 virtual space # An error report file with more information is saved as: # C:\Users\10729\AppData\Local\JetBrains\IntelliJIdea2023.1\compile-server\hs_err_pid37964.log
最新发布
09-12
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值