A module error occurred while running the JavaFX media application
When I run a JavaFX 11 application with the following command:
/usr/lib/jvm/java-11-openjdk-amd64/bin/java -p ~/.m2/repository/org/openjfx/javafx-swing/11/javafx-swing-11.jar: ~/.m2/repository/org/openjfx/javafx-swing/11/javafx-swing-11-linux.jar: ~/.m2/repository/org/openjfx/javafx-graphics/11/javafx-graphics-11.jar: ~/.m2/repository/org/openjfx/javafx-graphics/11/javafx-graphics-11-linux.jar: ~/.m2/repository/org/openjfx/javafx-base/11/javafx-base-11.jar: ~/.m2/repository/org/openjfx/javafx-base/11/javafx-base-11-linux.jar: ~/.m2/repository/org/openjfx/javafx-controls/11/javafx-controls-11.jar: ~/.m2/repository/org/openjfx/javafx-controls/11/javafx-controls-11-linux.jar: ~/.m2/repository/org/openjfx/javafx-media/11/javafx-media-11.jar: ~/.m2/repository/org/openjfx/javafx-media/11/javafx-media-11-linux.jar --add-modules javafx.controls,javafx.graphics -classpath ~/development/intellij/OpenPatrician/OpenPatricianStandalone/target/classes: ~/.OpenPatrician/plugins/maps/MinimalMap-Plugin.jar: ~/development/intellij/OpenPatrician/OpenPatricianDisplay/target/classes: ~/.m2/repository/ch/sahits/sahitsUtil/1.2.4/sahitsUtil-1.2.4.jar: ~/.m2/repository/junit/junit/4.12/junit-4.12.jar: ~/.m2/repository/org/hamcrest/hamcrest-core/1.3/hamcrest-core-1.3.jar: ~/.m2/repository/org/springframework/boot/spring-boot-starter-log4j2/2.1.0.RELEASE/spring-boot-starter-log4j2-2.1.0.RELEASE.jar: ~/.m2/repository/org/apache/logging/log4j/log4j-slf4j-impl/2.11.1/log4j-slf4j-impl-2.11.1.jar: ~/.m2/repository/org/slf4j/slf4j-api/1.7.25/slf4j-api-1.7.25.jar: ~/.m2/repository/org/apache/logging/log4j/log4j-api/2.11.1/log4j-api-2.11.1.jar: ~/.m2/repository/org/apache/logging/log4j/log4j-core/2.11.1/log4j-core-2.11.1.jar: ~/.m2/repository/org/apache/logging/log4j/log4j-jul/2.11.1/log4j-jul-2.11.1.jar: ~/.m2/repository/org/slf4j/jul-to-slf4j/1.7.25/jul-to-slf4j-1.7.25.jar: ~/.m2/repository/commons-cli/commons-cli/1.4/commons-cli-1.4.jar: ~/development/intellij/OpenPatrician/OpenPatricianImage/target/classes: ~/development/intellij/OpenPatrician/OpenPatricianModel/target/classes: ~/development/intellij/OpenPatrician/GameEvent/target/classes: ~/.m2/repository/org/glassfish/jaxb/jaxb-runtime/2.3.1/jaxb-runtime-2.3.1.jar: ~/.m2/repository/org/glassfish/jaxb/txw2/2.3.1/txw2-2.3.1.jar: ~/.m2/repository/com/sun/istack/istack-commons-runtime/3.0.7/istack-commons-runtime-3.0.7.jar: ~/.m2/repository/org/jvnet/staxex/stax-ex/1.8/stax-ex-1.8.jar: ~/.m2/repository/com/sun/xml/fastinfoset/fastinfoset/1.2.15/fastinfoset-1.2.15.jar: ~/.m2/repository/javax/activation/javax.activation-api/1.2.0/javax.activation-api-1.2.0.jar: ~/.m2/repository/org/openjfx/javafx-swing/11/javafx-swing-11.jar: ~/.m2/repository/org/openjfx/javafx-swing/11/javafx-swing-11-linux.jar: ~/.m2/repository/org/openjfx/javafx-graphics/11/javafx-graphics-11.jar: ~/.m2/repository/org/openjfx/javafx-graphics/11/javafx-graphics-11-linux.jar: ~/.m2/repository/org/openjfx/javafx-base/11/javafx-base-11.jar: ~/.m2/repository/org/openjfx/javafx-base/11/javafx-base-11-linux.jar: ~/development/intellij/OpenPatrician/OpenPatricianSound/target/classes: ~/development/intellij/OpenPatrician/OpenPatricianUtilities/target/classes: ~/.m2/repository/org/springframework/spring-beans/5.1.2.RELEASE/spring-beans-5.1.2.RELEASE.jar: ~/.m2/repository/org/openjfx/javafx-controls/11/javafx-controls-11.jar: ~/.m2/repository/org/openjfx/javafx-controls/11/javafx-controls-11-linux.jar: ~/.m2/repository/commons-io/commons-io/2.6/commons-io-2.6.jar: ~/.m2/repository/com/thoughtworks/xstream/xstream/1.4.10/xstream-1.4.10.jar: ~/.m2/repository/xmlpull/xmlpull/1.1.3.1/xmlpull-1.1.3.1.jar: ~/.m2/repository/xpp3/xpp3_min/1.1.4c/xpp3_min-1.1.4c.jar: ~/.m2/repository/javax/xml/bind/jaxb-api/2.3.1/jaxb-api-2.3.1.jar: ~/.m2/repository/javax/annotation/javax.annotation-api/1.3.2/javax.annotation-api-1.3.2.jar: ~/.m2/repository/org/openjfx/javafx-media/11/javafx-media-11.jar: ~/.m2/repository/org/openjfx/javafx-media/11/javafx-media-11-linux.jar: ~/.m2/repository/org/springframework/spring-context/5.1.2.RELEASE/spring-context-5.1.2.RELEASE.jar: ~/.m2/repository/org/springframework/spring-aop/5.1.2.RELEASE/spring-aop-5.1.2.RELEASE.jar: ~/.m2/repository/org/springframework/spring-expression/5.1.2.RELEASE/spring-expression-5.1.2.RELEASE.jar: ~/.m2/repository/org/springframework/spring-oxm/5.1.2.RELEASE/spring-oxm-5.1.2.RELEASE.jar: ~/.m2/repository/com/google/guava/guava/24.1-jre/guava-24.1-jre.jar: ~/.m2/repository/com/google/code/findbugs/jsr305/1.3.9/jsr305-1.3.9.jar: ~/.m2/repository/org/checkerframework/checker-compat-qual/2.0.0/checker-compat-qual-2.0.0.jar: ~/.m2/repository/com/google/errorprone/error_prone_annotations/2.1.3/error_prone_annotations-2.1.3.jar: ~/.m2/repository/com/google/j2objc/j2objc-annotations/1.1/j2objc-annotations-1.1.jar: ~/.m2/repository/org/codehaus/mojo/animal-sniffer-annotations/1.14/animal-sniffer-annotations-1.14.jar: ~/development/intellij/OpenPatrician/OpenPatricianJavaFX/target/classes: ~/development/intellij/OpenPatrician/OpenPatricianGameEvent/target/classes: ~/development/intellij/OpenPatrician/OpenPatricianClientServerInterface/target/classes: ~/.m2/repository/org/springframework/boot/spring-boot-starter-aop/2.1.0.RELEASE/spring-boot-starter-aop-2.1.0.RELEASE.jar: ~/.m2/repository/org/springframework/boot/spring-boot-starter/2.1.0.RELEASE/spring-boot-starter-2.1.0.RELEASE.jar: ~/.m2/repository/org/yaml/snakeyaml/1.23/snakeyaml-1.23.jar: ~/.m2/repository/org/aspectj/aspectjweaver/1.9.2/aspectjweaver-1.9.2.jar: ~/development/intellij/OpenPatrician/OpenPatricianServer/target/classes: ~/development/intellij/OpenPatrician/OpenPatricianEngine/target/classes: ~/.m2/repository/com/carrotsearch/hppc/0.7.2/hppc-0.7.2.jar: ~/.m2/repository/org/springframework/spring-core/5.1.2.RELEASE/spring-core-5.1.2.RELEASE.jar: ~/.m2/repository/org/springframework/spring-jcl/5.1.2.RELEASE/spring-jcl-5.1.2.RELEASE.jar: ~/.m2/repository/org/reflections/reflections/0.9.11/reflections-0.9.11.jar: ~/.m2/repository/org/javassist/javassist/3.21.0-GA/javassist-3.21.0-GA.jar: ~/development/intellij/OpenPatrician/OpenPatricianData/target/classes: ~/.m2/repository/org/projectlombok/lombok/1.18.2/lombok-1.18.2.jar: ~/.m2/repository/org/springframework/boot/spring-boot-devtools/2.1.0.RELEASE/spring-boot-devtools-2.1.0.RELEASE.jar: ~/.m2/repository/org/springframework/boot/spring-boot/2.1.0.RELEASE/spring-boot-2.1.0.RELEASE.jar: ~/.m2/repository/org/springframework/boot/spring-boot-autoconfigure/2.1.0.RELEASE/spring-boot-autoconfigure-2.1.0.RELEASE.jar ch.sahits.game.openpatrician.standalone.OpenPatricianApplication
I encountered this error:
Exception in thread "JavaFX Application Thread" java.lang.IllegalAccessError: class com.sun.media.jfxmediaimpl.NativeMediaManager (in unnamed module @0x4d7be377) cannot access class com.sun.glass.utils.NativeLibLoader (in module javafx.graphics) because module javafx.graphics does not export com.sun.glass.utils to unnamed module @0x4d7be377 at com.sun.media.jfxmediaimpl.NativeMediaManager.lambda$new$0(NativeMediaManager.java:136) at java.base/java.security.AccessController.doPrivileged(Native Method) at com.sun.media.jfxmediaimpl.NativeMediaManager.<init>(NativeMediaManager.java:107) at com.sun.media.jfxmediaimpl.NativeMediaManager$NativeMediaManagerInitializer.<clinit>(NativeMediaManager.java:78) at com.sun.media.jfxmediaimpl.NativeMediaManager.getDefaultInstance(NativeMediaManager.java:90) at com.sun.media.jfxmedia.MediaManager.canPlayProtocol(MediaManager.java:78) at com.sun.media.jfxmedia.locator.Locator.<init>(Locator.java:239) at com.sun.media.jfxmediaimpl.NativeMediaAudioClip.<init>(NativeMediaAudioClip.java:53) at com.sun.media.jfxmediaimpl.NativeMediaAudioClip.load(NativeMediaAudioClip.java:63) at com.sun.media.jfxmediaimpl.AudioClipProvider.load(AudioClipProvider.java:66) at com.sun.media.jfxmedia.AudioClip.load(AudioClip.java:135) at javafx.scene.media.AudioClip.<init>(AudioClip.java:83) at ch.sahits.game.openpatrician.sound.impl.LoopTrack.lambda$new$0(LoopTrack.java:26) at javafx.graphics/com.sun.javafx.application.PlatformImpl.lambda$runLater$10(PlatformImpl.java:428) at java.base/java.security.AccessController.doPrivileged(Native Method) at javafx.graphics/com.sun.javafx.application.PlatformImpl.lambda$runLater$11(PlatformImpl.java:427) at javafx.graphics/com.sun.glass.ui.invokelaterDispatcher$Future.run(invokelaterDispatcher.java:96) at javafx.graphics/com.sun.glass.ui.gtk.GtkApplication._runLoop(Native Method) at javafx.graphics/com.sun.glass.ui.gtk.GtkApplication.lambda$runLoop$11(GtkApplication.java:277) at java.base/java.lang.Thread.run(Thread.java:834)
As far as I know, there is a problem with my module settings for this exception, but I don't know what I need to change:
>Add add INS to – add modules, which? > Add – add - open to command with module > something completely different?
Solution
JavaFX 11 is divided into seven modules On the command line, you have:
--add-modules javafx.controls,javafx.graphics
And the mistake you get is:
java.lang.IllegalAccessError: class com.sun.media.jfxmediaimpl.NativeMediaManager (in unnamed module @0x4d7be377) cannot access class com.sun.glass.utils.NativeLibLoader (in module javafx.graphics) because module javafx.graphics does not export com.sun.glass.utils to unnamed module @0x4d7be377
It tells you com sun. media. A class in the jfxmediaimpl package is in an unnamed module and attempts to access JavaFX Internal member of graphics module The name of the package indicates that it belongs to JavaFX Media module However, this error indicates that you are using JavaFX. Net in the classpath Media module You need to include JavaFX in the – add modules command Media to use it in the module path:
--add-modules javafx.controls,javafx.graphics,javafx.media
This is due to JavaFX Graphics module info file It has qualified export and / or open instructions that allow JavaFX Media accesses these internal packages However, if everything involved is on the module path, the module system can only consider these instructions
In the related instructions, you do not need to include JavaFX. Java in the command Graphics, because you have added JavaFX controls. javafx. Controls and JavaFX Both media require JavaFX Graphics and JavaFX Base modules, so they are pulled in
When or if you modularize your code, you won't have to deal with – add modules You only need to declare the corresponding requires Directive:
module example { requires javafx.controls; // transitively requires javafx.base and javafx.graphics requires javafx.media; // transitively requires javafx.base and javafx.graphics // ... other directives ... /* * Don't forget to "exports" the package containing your Application * class to at least the javafx.graphics module. */ }
Then you must ensure that all modules, including your module, are on - module path (or - P) Your module will introduce the necessary dependencies
java -p <other-modules>;<javafx-modules>;<your-module> -m <your-module>/<main-class>