我正在开发一个客户端-服务器-Java应用程序,它可以在Mac以及Windows和Linux上运行。该应用程序有几个不同的客户端模块,这些模块应该从启动器应用程序执行。我看过ProcessBuilder类,但我似乎不适合我。我在stackoverflow中发现了一个线程,其中提出了一个使用Ant的示例(here)。我实现了一个执行客户端模块的方法:
public void launchAnt(ApplicationData applicationData) {
Project project = new Project();
project.setBaseDir(new File(System.getProperty("user.dir")));
project.init();
DefaultLogger logger = new DefaultLogger();
project.addBuildListener(logger);
logger.setOutputPrintStream(System.out);
logger.setErrorPrintStream(System.err);
logger.setMessageOutputLevel(Project.MSG_INFO);
System.setOut(new PrintStream(new DemuxOutputStream(project, false)));
System.setErr(new PrintStream(new DemuxOutputStream(project, true)));
project.fireBuildStarted();
System.out.println("ApplicationLauncher.launch(): Running");
Throwable caught = null;
try {
/**
* Create Java task
*/
Java javaTask = new Java();
javaTask.setTaskName("Run " + applicationData.getApplication().name());
javaTask.setProject(project);
javaTask.setFork(false);
javaTask.setFailonerror(true);
javaTask.setClassname(applicationData.getClassName());
/**
* Working directory
*/
File workdir = new File(System.getProperty("user.dir"));
if(workdir.exists()) {
javaTask.setDir(workdir);
} else {
System.out.println("ApplicationLauncher.launch(): ERROR: Unable to set workdir, " + workdir.getAbsolutePath() + " does note exist.");
}
/**
* Classpath
*/
Path path = new Path(project);
Collection<String> classpaths = getClasspath();
for (String classpath : classpaths) {
Path currPath = new Path(project, new File(classpath).getAbsolutePath());
path.add(currPath);
}
System.out.println("ApplicationLauncher.launch(): Classpath: " + path.toString());
javaTask.setClasspath(path);
/**
* Arguments
*/
Argument arg = javaTask.createArg();
arg.setValue(applicationData.getArguments());
/**
* Initiate and execute
*/
javaTask.init();
int ret = javaTask.executeJava();
System.out.println("ApplicationLauncher.launch(): Java task return code: " + ret);
} catch (BuildException e) {
caught = e;
}
project.log("ApplicationLauncher.launch(): Finished");
project.fireBuildFinished(caught);
}ApplicationData是一个对象,它包含有关要启动的应用程序的一些信息。这段代码运行良好,应用程序启动。问题出现在启动的应用程序中,该行导致ClassNotFoundException:
UIManager.setLookAndFeel(UIManager.getSystemLookAndFeelClassName());这是堆栈跟踪:
java.lang.ClassNotFoundException: apple.laf.AquaLookAndFeel
at org.apache.tools.ant.AntClassLoader.findClassInComponents(AntClassLoader.java:1361)
at org.apache.tools.ant.AntClassLoader.findClass(AntClassLoader.java:1311)
at org.apache.tools.ant.AntClassLoader.loadClass(AntClassLoader.java:1070)
at java.lang.ClassLoader.loadClass(ClassLoader.java:251)
at java.lang.ClassLoader.loadClassInternal(ClassLoader.java:374)
at java.lang.Class.forName0(Native Method)
at java.lang.Class.forName(Class.java:242)
at javax.swing.SwingUtilities.loadSystemClass(SwingUtilities.java:1788)
at javax.swing.UIManager.setLookAndFeel(UIManager.java:484)如果我尝试独立运行应用程序,它工作得很好。启动器应用程序包含与失败完全相同的行,并且在启动器中运行良好。看起来启动应用程序的ant方式有些不对劲。我比较了从启动器和独立执行应用程序时的System.properties和类路径(可以工作),没有区别。
我就是不明白为什么找不到这个类。还有没有人看到这个问题?欢迎提出任何建议!
谢谢!
发布于 2011-07-14 03:47:57
这些都是最难调试的错误。这是一个好兆头,代码可以在Ant之外正常运行,这就留下了一个类路径问题。检查项目的类路径,你的系统找不到"apple.laf.AquaLookAndFeel“。
https://stackoverflow.com/questions/6648295
复制相似问题