在创建ZipFile时获取ArrayOutOfBounds

时间:2013-07-01 10:50:27

标签: android unzip indexoutofboundsexception zipfile

我在创建ZipFile时得到以下堆栈:

final ZipFile zipFile = new ZipFile(mDownloadedFile);

错误:

java.lang.RuntimeException: An error occured while executing doInBackground()
    at android.os.AsyncTask$3.done(AsyncTask.java:299)
    at java.util.concurrent.FutureTask$Sync.innerSetException(FutureTask.java:273)
    at java.util.concurrent.FutureTask.setException(FutureTask.java:124)
    at java.util.concurrent.FutureTask$Sync.innerRun(FutureTask.java:307)
    at java.util.concurrent.FutureTask.run(FutureTask.java:137)
    at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1076)
    at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:569)
    at java.lang.Thread.run(Thread.java:856)
    Caused by: java.lang.ArrayIndexOutOfBoundsException: length=4096; regionStart=0; regionLength=-60060589
    at java.util.Arrays.checkOffsetAndCount(Arrays.java:1731)
    at libcore.io.IoBridge.read(IoBridge.java:427)
    at java.io.RandomAccessFile.read(RandomAccessFile.java:290)
    at java.util.zip.ZipFile$RAFStream.read(ZipFile.java:407)
    at java.io.InputStream.read(InputStream.java:163)
    at java.io.BufferedInputStream.fillbuf(BufferedInputStream.java:142)
    at java.io.BufferedInputStream.read(BufferedInputStream.java:309)
    at libcore.io.Streams.readFully(Streams.java:81)
    at java.util.zip.ZipEntry.<init>(ZipEntry.java:353)
    at java.util.zip.ZipFile.readCentralDir(ZipFile.java:365)
    at java.util.zip.ZipFile.<init>(ZipFile.java:132)
    at java.util.zip.ZipFile.<init>(ZipFile.java:103)
    at xxx.android.task.xxTask.unzipFile(xxTask.java:250)
    at xxx.android.task.xxTask.extract(xxTask.java:197)
    at xxx.android.task.xxTask.doInBackground(xxTask.java:157)
    at xxx.android.task.xxTask.doInBackground(xxTask.java:53)
    at android.os.AsyncTask$2.call(AsyncTask.java:287)
    at java.util.concurrent.FutureTask$Sync.innerRun(FutureTask.java:305)
    ... 4 more

我不能让它重现错误。它只是世界上发生的事情,在实时应用中,我通过邮件堆栈跟踪器收到了此错误。

有负区域长度= -60060589?这怎么可能?当我尝试在存储上创建已删除文件的文件时,是否会发生这种情况? 喜欢:下载 - 由于某种原因失败并删除文件 - 再次下载 - 崩溃。

编辑:mDownloadedFile是在下载开始之前创建的文件。在正常情况下,它是使用新的但在重试情况下创建的(当由于某种原因下载失败时)它再次使用该文件启动任务。我现在删除了这部分,因为它不需要,如果这可能是错误我已经修复它但也许有人知道不同的东西。

一些想象力?感谢

2 个答案:

答案 0 :(得分:0)

  

一些想象力?

这是我的尝试:
如果您将文件的长度存储在int中,那么一个可能的原因可能是文件大小超过int可容纳的最大允许值。换句话说,regionLength的数值太大,无法用int表示 您可以通过尝试使用大型zip文件(例如几GB)进行测试来确认这一点。如果是这样,那么将长度保持在long可以解决问题。

答案 1 :(得分:0)

我发现了一行代码:

FileOutputStream fileOutputStream = new FileOutputStream(mDownloadedFile, true);

第二个参数是append,意思是:

  

如果append为true且文件已存在,则将附加到;否则会被截断。

在最坏的情况下,由于重试功能,这种情况无穷无尽。正常情况下是下载和解压缩的5次重试。但在最坏的情况下,这种情况发生了无穷无尽,文件将变得如此大。

感谢Andy Res和他的想象力,这是找到这条线的关键: - )