I am running a Java desktop application on Windows 10 Pro using Tess4j; it was working fine with Java 1.8, am now trying to get it to run with Java 11 (11.0.15.1). When it calls net.sourceforge.tess4j.Tesseract.doOCR(BufferedImage bi), it gets a Throwable ExceptionInInitializerError, with a 'cause' exception indicating a call to net.sourceforge.tess4j.util.LoadLibs.getTesseractLibName().
Oddly enough, the application works fine from within eclipse, but fails running on its own (for instance, running "java -jar program.jar" from a cmd window). As I said, it was running with Java 1.8, and I might be able to get it running again by uninstalling Java and reinstalling that JRE, but there are other people that are going to use the application and it is not reasonable to expect them to use a Java version that is that old. I had the Maven dependency: <groupId>net.sourceforge.tess4j</groupId> <artifactId>tess4j</artifactId> <version>4.4.1</version> The only copy of tess4j-4.1.1.jar on my hard drive is in my .m2\repository\net\sourceforge\tess4j\tess4j\4.4.1. I have twice deleted it and updated my maven configuration to restore it, to insure it is not corrupted. I noticed that this is not the most recent Tess4j, so updated the dependency to 5.4.0 and rebuilt. This has the same results: works in eclipse, not from command line. The ExceptionInInitializerError is caused by an IllegalStateException: zip file closed error. Documentation indicates this could be a corrupted jar file or something similar. I don't know what jar file could be involved except the tess4j, and I've replaced that twice as I've said. I've also tried this with two versions of the Tesseract-OCR dll -- 5.0.1.20220118 and v5.2.0.20220712; they were both installed for "anyone on this computer" with default options. They give the same results. Can someone help me figure out what's wrong? Stack trace: java.lang.ExceptionInInitializerError at net.sourceforge.tess4j.Tesseract.init(Tesseract.java:427) at net.sourceforge.tess4j.Tesseract.doOCR(Tesseract.java:311) at net.sourceforge.tess4j.Tesseract.doOCR(Tesseract.java:294) at net.sourceforge.tess4j.Tesseract.doOCR(Tesseract.java:275) at net.sourceforge.tess4j.Tesseract.doOCR(Tesseract.java:259) at drivingrecordtool.file.DrivingRecordPDFTextReader.getOCRText(DrivingRecordPDFTextReader.java:152) at drivingrecordtool.file.DrivingRecordPDFTextReader.getText(DrivingRecordPDFTextReader.java:46) at drivingrecordtool.file.DrivingRecordFileReader.doInBackground(DrivingRecordFileReader.java:78) at drivingrecordtool.file.DrivingRecordFileReader.doInBackground(DrivingRecordFileReader.java:1) at java.desktop/javax.swing.SwingWorker$1.call(SwingWorker.java:304) at java.base/java.util.concurrent.FutureTask.run(FutureTask.java:264) at java.desktop/javax.swing.SwingWorker.run(SwingWorker.java:343) at java.base/java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1128) at java.base/java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:628) at java.base/java.lang.Thread.run(Thread.java:834) Caused by: java.lang.IllegalStateException: zip file closed at java.base/java.util.zip.ZipFile.ensureOpen(ZipFile.java:913) at java.base/java.util.zip.ZipFile.getEntry(ZipFile.java:348) at java.base/java.util.zip.ZipFile$1.getEntry(ZipFile.java:1130) at java.base/java.util.jar.JarFile.getEntry0(JarFile.java:586) at java.base/java.util.jar.JarFile.getEntry(JarFile.java:516) at java.base/sun.net.www.protocol.jar.URLJarFile.getEntry(URLJarFile.java:131) at java.base/java.util.jar.JarFile.getJarEntry(JarFile.java:478) at java.base/jdk.internal.loader.URLClassPath$JarLoader.getResource(URLClassPath.java:945) at java.base/jdk.internal.loader.URLClassPath.getResource(URLClassPath.java:315) at java.base/java.net.URLClassLoader$1.run(URLClassLoader.java:455) at java.base/java.net.URLClassLoader$1.run(URLClassLoader.java:452) at java.base/java.security.AccessController.doPrivileged(Native Method) at java.base/java.net.URLClassLoader.findClass(URLClassLoader.java:451) at java.base/java.lang.ClassLoader.loadClass(ClassLoader.java:588) at java.base/java.lang.ClassLoader.loadClass(ClassLoader.java:521) at net.sourceforge.tess4j.util.LoadLibs.getTesseractLibName(LoadLibs.java:95) at net.sourceforge.tess4j.util.LoadLibs.getTessAPIInstance(LoadLibs.java:85) at net.sourceforge.tess4j.TessAPI.<clinit>(TessAPI.java:42) ... 15 more -- You received this message because you are subscribed to the Google Groups "tesseract-ocr" group. To unsubscribe from this group and stop receiving emails from it, send an email to tesseract-ocr+unsubscr...@googlegroups.com. To view this discussion on the web visit https://groups.google.com/d/msgid/tesseract-ocr/56ccf988-a094-4442-9536-b4f70ba6aed2n%40googlegroups.com.