I’m evaluating Aspose.BarCode for java and I’m getting a ClassNotFoundException when running my code using a module path (using a module-info for my project). See stacktrace below. When running using the classpath, everything works fine. This is possibly related to the fact that the class (‘h’), which can not be found at runtime, is located in the package ‘com/aspose/barcode/internal/do’. A package named ‘do’ should not exist as this is a reserved keyword in java (see List of Java keywords - Wikipedia). When running jdeps --generate-module-info on the aspose-barcode.jar the resulting module-info does not exports this faulty package. Hence the resulting error when running this on the module path.
Can the use of a ‘do’ package be avoided when you are (I assume) obfuscating the jar so it can be used in projects using java modules?
Exception in thread “main” java.lang.NoClassDefFoundError: com/aspose/barcode/internal/do/h
at aspose.barcode@22.1-jdk18/com.aspose.barcode.internal.dl.g.a(Unknown Source)
at aspose.barcode@22.1-jdk18/com.aspose.barcode.internal.dl.g.a(Unknown Source)
at aspose.barcode@22.1-jdk18/com.aspose.barcode.generation.BarcodeGenerator.a(Unknown Source)
at aspose.barcode@22.1-jdk18/com.aspose.barcode.generation.BarcodeGenerator.save(Unknown Source)
at aspose.barcode@22.1-jdk18/com.aspose.barcode.generation.BarcodeGenerator.save(Unknown Source)
at aspose.barcode@22.1-jdk18/com.aspose.barcode.generation.BarcodeGenerator.save(Unknown Source)
at test/be.innersight.Test.main(Test.java:15)
Caused by: java.lang.ClassNotFoundException: com.aspose.barcode.internal.do.h
at java.base/jdk.internal.loader.BuiltinClassLoader.loadClass(BuiltinClassLoader.java:641)
at java.base/jdk.internal.loader.ClassLoaders$AppClassLoader.loadClass(ClassLoaders.java:188)
at java.base/java.lang.ClassLoader.loadClass(ClassLoader.java:520)
… 7 more
We have logged an investigation ticket with an id “BARCODEJAVA-1282” for your issue. We will look into the details of the problem and try to figure it out soon.
Once we have an update on it, we will let you know here.
@Aleksander.Grinin
In attachment a simple example. See the README file for compilation and running commands. First place the aspose-barcode-22.1-jdk18.jar under the lib directory as I have not bundled it with the example.
As mentioned I’m using java modules and thus compiling and running it using a module path.
I have tested this example with java 17 (openjdk build 17+35-2724) and java 9 (java hotspot build 9.0.4+11). The same result (see stacktrace above) twice.
I tested your scenario/case with your sample using modulepath on console (command prompt) using JDK11 and I got the same issue. The project is compiled fine but it does not run and produces the error, see the screenshot attached. We will be analyzing and looking into your issue soon. sc_shot1.png (23.9 KB)
matthieu.steyt
Generally speaking, this is acceptable to use keywords in compiled files.
For example, such proguard file defines the naming rules as list of keywords
But this issue is being reproduced (case with modules) and will be studied further. We adjusted the names of packages after obfuscation.
This fix will be included in release 22.2
Alright, thanks for the info. But if your license allows, you may try using Aspose.Barcode for Java v22.2 or Aspose.Barcode for Java v22.3 as these versions should fix your issue as well.