You may want to try VietOCR, a Java desktop app that uses Tess4J. It works with Java 8, 18, and probably 11 too.
http://vietocr.sf.net On Thursday, September 22, 2022 at 7:10:54 AM UTC-5 rcja...@gmail.com wrote: > 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/4f8fad3a-a091-4521-9c1b-2dbf747e99f5n%40googlegroups.com.