不一致 javax.imageio.IIOException:IHDR 块的长度错误

Inconsistent javax.imageio.IIOException: Bad length for IHDR chunk

我目前遇到一个非常奇怪的错误:当我使用参数 -Xdebug -Xnoagent -Xrunjdwp:transport=dt_socket,server=y,suspend=y,address=5005 启动我的应用程序并通过 Eclipse 远程连接时,一切正常。当我删除此参数(没有其他更改)时,出现以下异常:

Caused by: javax.imageio.IIOException: I/O error reading PNG header!
    at com.sun.imageio.plugins.png.PNGImageReader.readHeader(PNGImageReader.java:315) ~[na:1.8.0_92]
    at com.sun.imageio.plugins.png.PNGImageReader.readMetadata(PNGImageReader.java:654) ~[na:1.8.0_92]
    at com.sun.imageio.plugins.png.PNGImageReader.readImage(PNGImageReader.java:1248) ~[na:1.8.0_92]
    at com.sun.imageio.plugins.png.PNGImageReader.read(PNGImageReader.java:1606) ~[na:1.8.0_92]
    at javax.imageio.ImageIO.read(ImageIO.java:1448) ~[na:1.8.0_92]
    at javax.imageio.ImageIO.read(ImageIO.java:1400) ~[na:1.8.0_92]
    at com.jgoodies.application.ResourceConverters$DefaultConverter.convertImage(ResourceConverters.java:452) ~[retest.jar:1.2.0-SNAPSHOT]
    ... 43 common frames omitted
Caused by: javax.imageio.IIOException: Bad length for IHDR chunk!
    at com.sun.imageio.plugins.png.PNGImageReader.readHeader(PNGImageReader.java:247) ~[na:1.8.0_92]
    ... 49 common frames omitted

因为我真的,真的没有改变任何其他东西,我认为它与 this problem 无关,因为图像文件显然没有损坏。

由于这对我来说是一个外国项目,它可能必须与 3rd 方库或类似的东西一起做。我在 Mac、Java 1.8.0_92,如果这可能相关的话。

更新:如果我删除特定的 jar 文件,问题也会消失。但是,我稍后得到 NoClassDefFoundErrors,所以需要 jar 文件。关于如何进行的任何想法和建议?

我终于解决了这个问题,虽然我不完全确定是什么原因造成的以及为什么它是 Heisenbug。

如评论中 haraldK 所建议的那样,有问题的 jar 确实带有 ImageReaderSpi,但它也有某种混淆运行时魔法。