java.io.EOFException: Unexpected end of ZLIB input stream

JDK Bug System | Nelson Dcosta | 7 years ago
  1. 0

    Bug ID: JDK-6907252 ZipFileInputStream Not Thread-Safe

    java.com | 11 months ago
    java.io.EOFException: Unexpected end of ZLIB input stream
  2. 0

    FULL PRODUCT VERSION : java version "1.6.0_17" Java(TM) SE Runtime Environment (build 1.6.0_17-b04) Java HotSpot(TM) Client VM (build 14.3-b01, mixed mode, sharing) ADDITIONAL OS VERSION INFORMATION : Microsoft Windows Version 5.1 (Build 2600.xpsp_sp3_gdr.090804-1435 : Service Pack 3) A DESCRIPTION OF THE PROBLEM : Using an InputStream of a ZIP file entry seems not thread safe, and may even crash the VM. Below you'll find two crash reports. The first one is from my test run, the second one from the real issue we've encountered. It happens when reading an animating an animated GIF as a resource from a JAR file. Notice that the affected code is the AWT ImageFetcher. STEPS TO FOLLOW TO REPRODUCE THE PROBLEM : See test program. It's timing issue, so you may have to play with it for a while. I think the access violation happens at the following line, while accessing csize of a (already closed?) NULL entry, in function ZIP_Read: zip_util.c:1081 jlong entry_size = (entry->csize != 0) ? entry->csize : entry->size; EXPECTED VERSUS ACTUAL BEHAVIOR : EXPECTED - The exception that happens most of the time is quite good. java.io.EOFException: Unexpected end of ZLIB input stream at java.util.zip.ZipFile$1.fill(ZipFile.java:227) at java.util.zip.InflaterInputStream.read(InflaterInputStream.java:141) at java.util.zip.InflaterInputStream.read(InflaterInputStream.java:105) at CrashTest.main(CrashTest.java:31) ACTUAL - From time to time, there's a ZipException instead of the EOFException, with varying, less helpful, messages. java.util.zip.ZipException: invalid literal/length code at java.util.zip.InflaterInputStream.read(InflaterInputStream.java:147) at java.util.zip.InflaterInputStream.read(InflaterInputStream.java:105) at CrashTest.main(CrashTest.java:31) Other messages are: oversubscribed dynamic bit lengths tree invalid stored block lengths invalid block type The real problem is that the issue makes the VM crash some times - refer stack trace. ERROR MESSAGES/STACK TRACES THAT OCCUR : Attached seperatly REPRODUCIBILITY : This bug can be reproduced rarely. ---------- BEGIN SOURCE ---------- Any JAR with any file should do. Just make the entry big enough for the timer to hit the reading loop. import java.io.EOFException; import java.io.File; import java.io.IOException; import java.io.InputStream; import java.util.Timer; import java.util.TimerTask; import java.util.zip.ZipEntry; import java.util.zip.ZipFile; public class CrashTest { public static void main(final String[] args) throws Exception { final Timer timer = new Timer(); while (true) { final ZipFile zip = new ZipFile(new File("test.jar")); try { final ZipEntry entry = zip.getEntry("test.gif"); final InputStream in = zip.getInputStream(entry); try { timer.schedule(new TimerTask() { @Override public void run() { try { in.close(); } catch (final IOException ex) { ex.printStackTrace(System.err); } } }, 10); int c; do { c = in.read(); } while (c != -1); } finally { in.close(); } } catch (final EOFException ex) { // "Unexpected end of ZLIB input stream" } catch (final Exception ex) { ex.printStackTrace(System.err); } finally { zip.close(); } } } } ---------- END SOURCE ----------

    JDK Bug System | 7 years ago | Nelson Dcosta
    java.io.EOFException: Unexpected end of ZLIB input stream
  3. 0

    Exception: Unexpected end of ZLIB input stream

    Stack Overflow | 2 years ago | Ryoichiro Oka
    java.io.EOFException: Unexpected end of ZLIB input stream
  4. Speed up your debug routine!

    Automated exception search integrated into your IDE

  5. 0

    Unexpected end of ZLIB input stream while reading InputStream into a file

    Stack Overflow | 2 years ago | birdy
    org.springframework.amqp.rabbit.listener.ListenerExecutionFailedException: Listener method 'handleMessage' threw exception
  6. 0

    Bug ID: JDK-4040920 Catch unexpected end of ZLIB while reading from InputStream for some ZIP files.

    sun.com | 6 months ago
    java.io.EOFException: Unexpected end of ZLIB input stream

    Not finding the right solution?
    Take a tour to get the most out of Samebug.

    Tired of useless tips?

    Automated exception search integrated into your IDE

    Root Cause Analysis

    1. java.io.EOFException

      Unexpected end of ZLIB input stream

      at java.util.zip.ZipFile$1.fill()
    2. Java RT
      InflaterInputStream.read
      1. java.util.zip.ZipFile$1.fill(ZipFile.java:227)
      2. java.util.zip.InflaterInputStream.read(InflaterInputStream.java:141)
      3. java.util.zip.InflaterInputStream.read(InflaterInputStream.java:105)
      3 frames
    3. Unknown
      CrashTest.main
      1. CrashTest.main(CrashTest.java:31)
      1 frame