最近做一个项目,用到了ToolProvider.getSystemJavaCompiler()编译Java类

出现一个奇怪的现象:在Eclipse IDE中测试完全没有问题,部署到Web 服务器中从前台界面跑起来,就会卡着不动,也没有报错,跟踪了一下,找到ToolProvider.getSystemJavaCompiler()为null


上网搜了下,直接说就是找不到jdk lib目录下tools.jar文件,没法编译

之前我设置JAVA_HOME在java\jdk
更改为Java\jre,同时将jdk\lib下将tools.jar复制到jre\lib下

OK

编译通过


工程可以正常运行了,现在回过头来,研究下为什么要这样做呢

查看ToolProvider的源码,发现这段代码

private static final String[] defaultToolsLocation
= { "lib", "tools.jar" };
private static Class<?> findClass()
throws MalformedURLException, ClassNotFoundException
{
try {
return enableAsserts(Class.forName(defaultJavaCompilerName, false, null));
} catch (ClassNotFoundException e) {
// ignored, try looking else where
}
File file = new File(System.getProperty("java.home"));
if (file.getName().equalsIgnoreCase("jre"))
file = file.getParentFile();
for (String name : defaultToolsLocation)
file = new File(file, name);
URL[] urls = {file.toURI().toURL()};
ClassLoader cl = URLClassLoader.newInstance(urls);
cl.setPackageAssertionStatus("com.sun.tools.javac", true);
return Class.forName(defaultJavaCompilerName, false, cl);
}

它编译文件时,会找到JAVA_HOME的jre\lib\tools.jar

但是值得注意的是tools.jar并不在jre中,它是在jdk的安装目录下

所以,手动把这个jar文件从jdk目录下拷贝到了jre目录下,再次运行上面的代码就没有问题了!