Zip 提取失败

发布于 2024-12-20 10:55:51 字数 7765 浏览 0 评论 0原文

我需要将资产文件夹中的 zip 文件解压到 SD 卡,才能完成安装。

由于zip大约有10MB大,我将其作为mp3文件放在assets文件夹中,然后将存档复制到SD卡(md5和相同)。

然后是解压它的问题:我尝试了 stackoverflow 上 zip 文件的所有解压方法,但没有一个有效。

我正在使用的那个可以部分工作 - 有时它会提取所有文件,但大多数时候它会在中间崩溃(给我一个非常长的调试输出)。

我附上了代码和部分输出。

有人可以帮忙吗?而且它不一定是 zip 文件,任何其他存档格式(例如 tar)也可以。 /edit:我在服务中运行此代码,这可能是一个问题吗?

提取代码:

private final static int CHUNK_SIZE = 32 * 1024;

public static void unzipFile( String zipFile, String directory) 
    throws IOException
{ 
    byte[] _fileIOBuffer = new byte[CHUNK_SIZE];
    ZipInputStream in = null; 
    FileOutputStream os = null; 
    try 
    {
        in = new ZipInputStream (new FileInputStream(new File(zipFile))); 
        ZipEntry entry = null; 
        while ((entry = in.getNextEntry ())!= null) 
        { 
            String entryName = entry.getName();                 
            if (entry.isDirectory ()) { 
                File file = new File (directory, entryName); 
                file.mkdirs(); 
            } 
            else { 
                File file = new File(directory, entryName);
                if (file.exists()){
                    file.delete();  // I don't know how to append, so delete it always
                }
                os = new FileOutputStream (file); 

                int bytesRead = 0; 
                while ((bytesRead = in.read (_fileIOBuffer))!= -1) {
                    os.write(_fileIOBuffer, 0, bytesRead);
                    // progress procedure
                }
                os.close();
            }
        }
    }
    catch (FileNotFoundException e) {        
        Log.v("unzip", e.getMessage());
    } 
    catch (IOException e) {
        Log.v("unzip", e.getMessage());
    } 
    finally{
        if (in != null ){
            in.close();
        }
        if (os != null ){
            os.close();
        }
    }
}

一些日志输出:

W/dalvikvm(23094): "Binder Thread #1" prio=5 tid=5 NATIVE
W/dalvikvm(23094):   | group="main" sCount=1 dsCount=0 s=N obj=0x46e7a300 self=0x12aba8
W/dalvikvm(23094):   | sysTid=23098 nice=0 sched=3/0 cgrp=unknown handle=1369000
W/dalvikvm(23094):   | schedstat=( 806168347 48580865164 5171 )
W/dalvikvm(23094):   at dalvik.system.NativeStart.run(Native Method)
W/dalvikvm(23094): 
W/dalvikvm(23094): "Compiler" daemon prio=5 tid=4 VMWAIT
W/dalvikvm(23094):   | group="system" sCount=1 dsCount=0 s=N obj=0x46e732a0 self=0x125638
W/dalvikvm(23094):   | sysTid=23097 nice=0 sched=3/0 cgrp=unknown handle=1225832
W/dalvikvm(23094):   | schedstat=( 864668103 47259131847 4450 )
W/dalvikvm(23094):   at dalvik.system.NativeStart.run(Native Method)
W/dalvikvm(23094): 
W/dalvikvm(23094): "Signal Catcher" daemon prio=5 tid=3 RUNNABLE
W/dalvikvm(23094):   | group="system" sCount=0 dsCount=0 s=N obj=0x46e731e8 self=0x12b278
W/dalvikvm(23094):   | sysTid=23096 nice=0 sched=3/0 cgrp=unknown handle=1308736
W/dalvikvm(23094):   | schedstat=( 113256650 45104360665 3544 )
W/dalvikvm(23094):   at dalvik.system.NativeStart.run(Native Method)
W/dalvikvm(23094): 
W/dalvikvm(23094): "HeapWorker" daemon prio=5 tid=2 VMWAIT
W/dalvikvm(23094):   | group="system" sCount=1 dsCount=0 s=N obj=0x448f6f78 self=0x149d40
W/dalvikvm(23094):   | sysTid=23095 nice=0 sched=3/0 cgrp=unknown handle=1304104
W/dalvikvm(23094):   | schedstat=( 1423918773 45794713359 3888 )
W/dalvikvm(23094):   at dalvik.system.NativeStart.run(Native Method)
W/dalvikvm(23094): 
W/dalvikvm(28514): 
W/dalvikvm(28514): 
W/dalvikvm(28514): ----- pid 28514 at 2011-12-10 17:08:17 -----
W/dalvikvm(28514): Cmd line: com.google.android.apps.maps:NetworkLocationService
W/dalvikvm(28514): 
W/dalvikvm(28514): DALVIK THREADS:
W/dalvikvm(28514): "main" prio=5 tid=1 WAIT
W/dalvikvm(28514):   | group="main" sCount=1 dsCount=0 s=N obj=0x4001d938 self=0xcd98
W/dalvikvm(28514):   | sysTid=28514 nice=0 sched=3/0 cgrp=unknown handle=-1345017808
W/dalvikvm(28514):   | schedstat=( 1203913753 1177626459 364 )
W/dalvikvm(28514):   at java.lang.Object.wait(Native Method)
W/dalvikvm(28514):   - waiting on <0x46faf6c8> (a android.os.MessageQueue)
W/dalvikvm(28514):   at java.lang.Object.wait(Object.java:288)
W/dalvikvm(28514):   at android.os.MessageQueue.next(MessageQueue.java:146)
W/dalvikvm(28514):   at android.os.Looper.loop(Looper.java:110)
W/dalvikvm(28514):   at android.app.ActivityThread.main(ActivityThread.java:4627)
W/dalvikvm(28514):   at java.lang.reflect.Method.invokeNative(Native Method)
W/dalvikvm(28514):   at java.lang.reflect.Method.invoke(Method.java:521)
W/dalvikvm(28514):   at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:858)
W/dalvikvm(28514):   at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:616)
W/dalvikvm(28514):   at dalvik.system.NativeStart.main(Native Method)
W/dalvikvm(28514): 
W/dalvikvm(28514): "[email protected]@47054bc0" daemon prio=5 tid=16 WAIT
W/dalvikvm(28514):   | group="main" sCount=1 dsCount=0 s=N obj=0x47036980 self=0x242a70
W/dalvikvm(28514):   | sysTid=28535 nice=0 sched=3/0 cgrp=unknown handle=1227616
W/dalvikvm(28514):   | schedstat=( 206874 20758542 2 )
W/dalvikvm(28514):   at java.lang.Object.wait(Native Method)
W/dalvikvm(28514):   - waiting on <0x46fd3838> (a java.lang.ref.ReferenceQueue)
W/dalvikvm(28514):   at java.lang.Object.wait(Object.java:326)
W/dalvikvm(28514):   at java.lang.ref.ReferenceQueue.remove(ReferenceQueue.java:107)
W/dalvikvm(28514):   at java.lang.ref.ReferenceQueue.remove(ReferenceQueue.java:80)
W/dalvikvm(28514):   at org.apache.http.impl.conn.tsccm.RefQueueWorker.run(RefQueueWorker.java:102)
W/dalvikvm(28514):   at java.lang.Thread.run(Thread.java:1096)
W/dalvikvm(28514): 
W/dalvikvm(28514): "NetworkLocationCallbackRunner" prio=5 tid=15 WAIT
W/dalvikvm(28514):   | group="main" sCount=1 dsCount=0 s=N obj=0x470429d8 self=0x13c4c8
W/dalvikvm(28514):   | sysTid=28534 nice=-4 sched=3/0 cgrp=unknown handle=1248160
W/dalvikvm(28514):   | schedstat=( 568270822 541402506 640 )
W/dalvikvm(28514):   at java.lang.Object.wait(Native Method)
W/dalvikvm(28514):   - waiting on <0x47112b88> (a android.os.MessageQueue)
W/dalvikvm(28514):   at java.lang.Object.wait(Object.java:288)
W/dalvikvm(28514):   at android.os.MessageQueue.next(MessageQueue.java:146)
W/dalvikvm(28514):   at android.os.Looper.loop(Looper.java:110)
W/dalvikvm(28514):   at com.google.android.location.os.real.i.run((null):-1)
W/dalvikvm(28514):   at java.lang.Thread.run(Thread.java:1096)
W/dalvikvm(28514): 
W/dalvikvm(28514): "Thread-16" daemon prio=1 tid=14 WAIT
W/dalvikvm(28514):   | group="main" sCount=1 dsCount=0 s=N obj=0x470706a0 self=0x243c38
W/dalvikvm(28514):   | sysTid=28533 nice=19 sched=3/0 cgrp=unknown handle=2374056
W/dalvikvm(28514):   | schedstat=( 343958 16096459 3 )
W/dalvikvm(28514):   at java.lang.Object.wait(Native Method)
W/dalvikvm(28514):   - waiting on <0x470709c8> (a java.lang.VMThread)
W/dalvikvm(28514):   at java.lang.Thread.parkFor(Thread.java:1535)
W/dalvikvm(28514):   at java.lang.LangAccessImpl.parkFor(LangAccessImpl.java:48)
W/dalvikvm(28514):   at sun.misc.Unsafe.park(Unsafe.java:317)
W/dalvikvm(28514):   at java.util.concurrent.locks.LockSupport.park(LockSupport.java:131)
W/dalvikvm(28514):   at java.util.concurrent.locks.AbstractQueuedSynchronizer$ConditionObject.await(AbstractQueuedSynchronizer.java:1996)
W/dalvikvm(28514):   at java.util.concurrent.LinkedBlockingQueue.take(LinkedBlockingQueue.java:359)
W/dalvikvm(28514):   at b.a.run((null):-1)

I need to decompress a zip file from my assets folder to the SD card, in order to complete the installation.

As the zip is about 10MB big, I put it as a mp3 file in the assets folder and then copy the archive to the SD card (the md5 sums are the same).

Then there is the problem of extracting it: I tried every single decompression method on stackoverflow for zip files, but none of them works.

The one I am using works partly - sometimes it extracts all the files, but most of the time it crashes in the middle (giving me an extremely long debug output).

I attached the code and parts of the output.

Can anyone help? And it doesn't have to be a zip file, any other archive format like tar is fine as well. /edit: I run this code in a service, might this be a problem?

Code for extracting:

private final static int CHUNK_SIZE = 32 * 1024;

public static void unzipFile( String zipFile, String directory) 
    throws IOException
{ 
    byte[] _fileIOBuffer = new byte[CHUNK_SIZE];
    ZipInputStream in = null; 
    FileOutputStream os = null; 
    try 
    {
        in = new ZipInputStream (new FileInputStream(new File(zipFile))); 
        ZipEntry entry = null; 
        while ((entry = in.getNextEntry ())!= null) 
        { 
            String entryName = entry.getName();                 
            if (entry.isDirectory ()) { 
                File file = new File (directory, entryName); 
                file.mkdirs(); 
            } 
            else { 
                File file = new File(directory, entryName);
                if (file.exists()){
                    file.delete();  // I don't know how to append, so delete it always
                }
                os = new FileOutputStream (file); 

                int bytesRead = 0; 
                while ((bytesRead = in.read (_fileIOBuffer))!= -1) {
                    os.write(_fileIOBuffer, 0, bytesRead);
                    // progress procedure
                }
                os.close();
            }
        }
    }
    catch (FileNotFoundException e) {        
        Log.v("unzip", e.getMessage());
    } 
    catch (IOException e) {
        Log.v("unzip", e.getMessage());
    } 
    finally{
        if (in != null ){
            in.close();
        }
        if (os != null ){
            os.close();
        }
    }
}

Some log output:

W/dalvikvm(23094): "Binder Thread #1" prio=5 tid=5 NATIVE
W/dalvikvm(23094):   | group="main" sCount=1 dsCount=0 s=N obj=0x46e7a300 self=0x12aba8
W/dalvikvm(23094):   | sysTid=23098 nice=0 sched=3/0 cgrp=unknown handle=1369000
W/dalvikvm(23094):   | schedstat=( 806168347 48580865164 5171 )
W/dalvikvm(23094):   at dalvik.system.NativeStart.run(Native Method)
W/dalvikvm(23094): 
W/dalvikvm(23094): "Compiler" daemon prio=5 tid=4 VMWAIT
W/dalvikvm(23094):   | group="system" sCount=1 dsCount=0 s=N obj=0x46e732a0 self=0x125638
W/dalvikvm(23094):   | sysTid=23097 nice=0 sched=3/0 cgrp=unknown handle=1225832
W/dalvikvm(23094):   | schedstat=( 864668103 47259131847 4450 )
W/dalvikvm(23094):   at dalvik.system.NativeStart.run(Native Method)
W/dalvikvm(23094): 
W/dalvikvm(23094): "Signal Catcher" daemon prio=5 tid=3 RUNNABLE
W/dalvikvm(23094):   | group="system" sCount=0 dsCount=0 s=N obj=0x46e731e8 self=0x12b278
W/dalvikvm(23094):   | sysTid=23096 nice=0 sched=3/0 cgrp=unknown handle=1308736
W/dalvikvm(23094):   | schedstat=( 113256650 45104360665 3544 )
W/dalvikvm(23094):   at dalvik.system.NativeStart.run(Native Method)
W/dalvikvm(23094): 
W/dalvikvm(23094): "HeapWorker" daemon prio=5 tid=2 VMWAIT
W/dalvikvm(23094):   | group="system" sCount=1 dsCount=0 s=N obj=0x448f6f78 self=0x149d40
W/dalvikvm(23094):   | sysTid=23095 nice=0 sched=3/0 cgrp=unknown handle=1304104
W/dalvikvm(23094):   | schedstat=( 1423918773 45794713359 3888 )
W/dalvikvm(23094):   at dalvik.system.NativeStart.run(Native Method)
W/dalvikvm(23094): 
W/dalvikvm(28514): 
W/dalvikvm(28514): 
W/dalvikvm(28514): ----- pid 28514 at 2011-12-10 17:08:17 -----
W/dalvikvm(28514): Cmd line: com.google.android.apps.maps:NetworkLocationService
W/dalvikvm(28514): 
W/dalvikvm(28514): DALVIK THREADS:
W/dalvikvm(28514): "main" prio=5 tid=1 WAIT
W/dalvikvm(28514):   | group="main" sCount=1 dsCount=0 s=N obj=0x4001d938 self=0xcd98
W/dalvikvm(28514):   | sysTid=28514 nice=0 sched=3/0 cgrp=unknown handle=-1345017808
W/dalvikvm(28514):   | schedstat=( 1203913753 1177626459 364 )
W/dalvikvm(28514):   at java.lang.Object.wait(Native Method)
W/dalvikvm(28514):   - waiting on <0x46faf6c8> (a android.os.MessageQueue)
W/dalvikvm(28514):   at java.lang.Object.wait(Object.java:288)
W/dalvikvm(28514):   at android.os.MessageQueue.next(MessageQueue.java:146)
W/dalvikvm(28514):   at android.os.Looper.loop(Looper.java:110)
W/dalvikvm(28514):   at android.app.ActivityThread.main(ActivityThread.java:4627)
W/dalvikvm(28514):   at java.lang.reflect.Method.invokeNative(Native Method)
W/dalvikvm(28514):   at java.lang.reflect.Method.invoke(Method.java:521)
W/dalvikvm(28514):   at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:858)
W/dalvikvm(28514):   at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:616)
W/dalvikvm(28514):   at dalvik.system.NativeStart.main(Native Method)
W/dalvikvm(28514): 
W/dalvikvm(28514): "[email protected]@47054bc0" daemon prio=5 tid=16 WAIT
W/dalvikvm(28514):   | group="main" sCount=1 dsCount=0 s=N obj=0x47036980 self=0x242a70
W/dalvikvm(28514):   | sysTid=28535 nice=0 sched=3/0 cgrp=unknown handle=1227616
W/dalvikvm(28514):   | schedstat=( 206874 20758542 2 )
W/dalvikvm(28514):   at java.lang.Object.wait(Native Method)
W/dalvikvm(28514):   - waiting on <0x46fd3838> (a java.lang.ref.ReferenceQueue)
W/dalvikvm(28514):   at java.lang.Object.wait(Object.java:326)
W/dalvikvm(28514):   at java.lang.ref.ReferenceQueue.remove(ReferenceQueue.java:107)
W/dalvikvm(28514):   at java.lang.ref.ReferenceQueue.remove(ReferenceQueue.java:80)
W/dalvikvm(28514):   at org.apache.http.impl.conn.tsccm.RefQueueWorker.run(RefQueueWorker.java:102)
W/dalvikvm(28514):   at java.lang.Thread.run(Thread.java:1096)
W/dalvikvm(28514): 
W/dalvikvm(28514): "NetworkLocationCallbackRunner" prio=5 tid=15 WAIT
W/dalvikvm(28514):   | group="main" sCount=1 dsCount=0 s=N obj=0x470429d8 self=0x13c4c8
W/dalvikvm(28514):   | sysTid=28534 nice=-4 sched=3/0 cgrp=unknown handle=1248160
W/dalvikvm(28514):   | schedstat=( 568270822 541402506 640 )
W/dalvikvm(28514):   at java.lang.Object.wait(Native Method)
W/dalvikvm(28514):   - waiting on <0x47112b88> (a android.os.MessageQueue)
W/dalvikvm(28514):   at java.lang.Object.wait(Object.java:288)
W/dalvikvm(28514):   at android.os.MessageQueue.next(MessageQueue.java:146)
W/dalvikvm(28514):   at android.os.Looper.loop(Looper.java:110)
W/dalvikvm(28514):   at com.google.android.location.os.real.i.run((null):-1)
W/dalvikvm(28514):   at java.lang.Thread.run(Thread.java:1096)
W/dalvikvm(28514): 
W/dalvikvm(28514): "Thread-16" daemon prio=1 tid=14 WAIT
W/dalvikvm(28514):   | group="main" sCount=1 dsCount=0 s=N obj=0x470706a0 self=0x243c38
W/dalvikvm(28514):   | sysTid=28533 nice=19 sched=3/0 cgrp=unknown handle=2374056
W/dalvikvm(28514):   | schedstat=( 343958 16096459 3 )
W/dalvikvm(28514):   at java.lang.Object.wait(Native Method)
W/dalvikvm(28514):   - waiting on <0x470709c8> (a java.lang.VMThread)
W/dalvikvm(28514):   at java.lang.Thread.parkFor(Thread.java:1535)
W/dalvikvm(28514):   at java.lang.LangAccessImpl.parkFor(LangAccessImpl.java:48)
W/dalvikvm(28514):   at sun.misc.Unsafe.park(Unsafe.java:317)
W/dalvikvm(28514):   at java.util.concurrent.locks.LockSupport.park(LockSupport.java:131)
W/dalvikvm(28514):   at java.util.concurrent.locks.AbstractQueuedSynchronizer$ConditionObject.await(AbstractQueuedSynchronizer.java:1996)
W/dalvikvm(28514):   at java.util.concurrent.LinkedBlockingQueue.take(LinkedBlockingQueue.java:359)
W/dalvikvm(28514):   at b.a.run((null):-1)

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(1

独守阴晴ぅ圆缺 2024-12-27 10:55:51

in.read(byte[]) 不是在 ZipInputStream 上定义的,而是在父类 FilterInputStream 上定义的。我认为它扰乱了 ZipInputStream 的入口边界。

相反,尝试使用 in.read(_fileIOBuffer, 0, _fileIOBuffer.length)

in.read(byte[]) in not defined on ZipInputStream but rather on parent class FilterInputStream. I assume it messes the ZipInputStream's entry boundaries.

Instead try using in.read(_fileIOBuffer, 0, _fileIOBuffer.length).

~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文