Для проблемы, с которой я сталкиваюсь, важно знать, что мы развертываем приложение JavaFX с Java 8 (242) вместе с JavaFX Runtime 202. Для сборки приложения мы используем упаковщик javafx, который создает EXE-файл запустить приложение на Windows и развернуть рядом с ним указанную c среду выполнения.
Таким образом, оно работало уже много лет на многих различных системах до сегодняшнего дня, когда у нас внезапно возникла проблема с одним указанным c клиент, где приложение отказывается запускаться.
После долгого времени копания мы узнали, что наш клиент запускает приложение по сетевому пути UN C. Я пробовал много псевдонимов UN C, и кажется, что сгенерированный упаковщиком javafx EXE-файл не может обработать символ _
в разделе имени хоста пути UN C. Например:
\\stack_overflow.de\path\to\application\application.exe
Запуск приложения с использованием сгенерированного EXE-файла упаковщика приводит к исключению времени выполнения:
java.lang.RuntimeException: No toolkit found
at com.sun.javafx.tk.Toolkit.getToolkit(Toolkit.java:260)
at com.sun.javafx.application.PlatformImpl.startup(PlatformImpl.java:209)
at com.sun.javafx.application.LauncherImpl.startToolkit(LauncherImpl.java:675)
at com.sun.javafx.application.LauncherImpl.launchApplication1(LauncherImpl.java:695)
at com.sun.javafx.application.LauncherImpl.lambda$launchApplication$154(LauncherImpl.java:182)
at java.lang.Thread.run(Unknown Source)
Проблема также возникает при использовании неизмененного javafx Пример, сгенерированный с помощью eclipse и использующий файл EXE, сгенерированный упаковщиком javafx.
Приложение CFG для файла EXE выглядит следующим образом:
[Application]
app.name=application
app.mainjar=application.jar
app.version=1.0.3
app.preferences.id=applicationId
app.mainclass=com/path/to/main/Main
app.classpath=libs/somejar.jar;libs/morejars.jar;.
app.runtime=$APPDIR\runtime
app.identifier=applicationId
[JVMOptions]
[JVMUserOptions]
[ArgOptions]
Когда я запускаю приложение с помощью java -jar application.jar
все кажется хорошо. Когда я запускаю приложение с любого другого подключенного сетевого диска или по пути UN C без _
, сгенерированный файл запуска EXE также работает нормально.
Исключение возникает при вызове метода запуска класса Application:
import javafx.application.Application;
import javafx.stage.Stage;
import javafx.scene.Scene;
import javafx.scene.layout.BorderPane;
public class Main extends Application {
@Override
public void start(Stage primaryStage) {
//WE ARE NOT GETTING HERE; WHEN STARTED FROM EXE WITHIN AN UNC PATH WITH '_'
try {
BorderPane root = new BorderPane();
Scene scene = new Scene(root,400,400);
scene.getStylesheets().add(getClass().getResource("application.css").toExternalForm());
primaryStage.setScene(scene);
primaryStage.show();
} catch(Exception e) {
e.printStackTrace();
}
}
public static void main(String[] args) {
launch(args); //<-- here the error occurs
}
}
Кто-нибудь сталкивался с такой ситуацией раньше и знает, делаем ли мы что-то не так?