使用Android下载ZIP文件

使用Android下载ZIP文件,android,download,runtime-error,Android,Download,Runtime Error,我正在尝试从服务器下载zip文件。为此,我使用以下代码: String path = Environment.getExternalStorageDirectory().toString() + "/KaLePro/"; StartscreenModel sm = StartscreenModel.getInstance(); //TODO FIX: unkown error! Bring usb-cable to find out!

我正在尝试从服务器下载zip文件。为此,我使用以下代码:

        String path = Environment.getExternalStorageDirectory().toString() + "/KaLePro/";
        StartscreenModel sm = StartscreenModel.getInstance();
        //TODO FIX: unkown error! Bring usb-cable to find out!
        try {
            URL url = new URL(urlString);
            System.out.println("Connecting to " + url);
            HttpURLConnection connection = (HttpURLConnection) url.openConnection();
            connection.setRequestMethod("GET");
            connection.setDoOutput(true);
            connection.connect();
            int fileLength = connection.getContentLength();

            File PATH = new File(path + "import/");
            if (!PATH.exists()) {
                PATH.mkdirs();
            }

            File outputFile = new File(PATH, "tmp.zip");

            InputStream input = connection.getInputStream();
            OutputStream output = new FileOutputStream(outputFile);

            byte data[] = new byte[1024];
            long total = 0;
            int count;
            sm.setSubMax(100);
            while ((count = input.read(data)) != -1) {
                total += count;
                sm.setSubStep((int) (total * 100 / fileLength));
                output.write(data, 0, count);
            }

            output.flush();
            output.close();
            input.close();
            Toast.makeText(Booklist.this, "Download fertig.", Toast.LENGTH_SHORT).show();
        } catch (MalformedURLException e) {
            Toast.makeText(Booklist.this, "Keine gültige URL", Toast.LENGTH_SHORT).show();
        } catch (IOException e) {
            Toast.makeText(Booklist.this, "Keine Verbindung zur URL", Toast.LENGTH_SHORT).show();
        }
但当我尝试下载该文件时,会出现以下Logcat错误:

10-23 10:22:37.867: E/AndroidRuntime(21490): FATAL EXCEPTION: main
10-23 10:22:37.867: E/AndroidRuntime(21490): android.os.NetworkOnMainThreadException
10-23 10:22:37.867: E/AndroidRuntime(21490):    at android.os.StrictMode$AndroidBlockGuardPolicy.onNetwork(StrictMode.java:1118)
10-23 10:22:37.867: E/AndroidRuntime(21490):    at libcore.io.BlockGuardOs.connect(BlockGuardOs.java:84)
10-23 10:22:37.867: E/AndroidRuntime(21490):    at libcore.io.IoBridge.connectErrno(IoBridge.java:127)
10-23 10:22:37.867: E/AndroidRuntime(21490):    at libcore.io.IoBridge.connect(IoBridge.java:112)
10-23 10:22:37.867: E/AndroidRuntime(21490):    at java.net.PlainSocketImpl.connect(PlainSocketImpl.java:192)
10-23 10:22:37.867: E/AndroidRuntime(21490):    at java.net.PlainSocketImpl.connect(PlainSocketImpl.java:459)
10-23 10:22:37.867: E/AndroidRuntime(21490):    at java.net.Socket.connect(Socket.java:842)
10-23 10:22:37.867: E/AndroidRuntime(21490):    at libcore.net.http.HttpConnection.<init>(HttpConnection.java:76)
10-23 10:22:37.867: E/AndroidRuntime(21490):    at libcore.net.http.HttpConnection.<init>(HttpConnection.java:50)
10-23 10:22:37.867: E/AndroidRuntime(21490):    at libcore.net.http.HttpConnection$Address.connect(HttpConnection.java:340)
10-23 10:22:37.867: E/AndroidRuntime(21490):    at libcore.net.http.HttpConnectionPool.get(HttpConnectionPool.java:87)
10-23 10:22:37.867: E/AndroidRuntime(21490):    at libcore.net.http.HttpConnection.connect(HttpConnection.java:128)
10-23 10:22:37.867: E/AndroidRuntime(21490):    at libcore.net.http.HttpEngine.openSocketConnection(HttpEngine.java:315)
10-23 10:22:37.867: E/AndroidRuntime(21490):    at libcore.net.http.HttpEngine.connect(HttpEngine.java:310)
10-23 10:22:37.867: E/AndroidRuntime(21490):    at libcore.net.http.HttpEngine.sendSocketRequest(HttpEngine.java:289)
10-23 10:22:37.867: E/AndroidRuntime(21490):    at libcore.net.http.HttpEngine.sendRequest(HttpEngine.java:239)
10-23 10:22:37.867: E/AndroidRuntime(21490):    at libcore.net.http.HttpURLConnectionImpl.connect(HttpURLConnectionImpl.java:80)
10-23 10:22:37.867: E/AndroidRuntime(21490):    at de.isogon.kalepro.activities.Booklist$2.onDownload(Booklist.java:194)
10-23 10:22:37.867: E/AndroidRuntime(21490):    at de.isogon.kalepro.views.dialogs.DialogDownload$2.onClick(DialogDownload.java:76)
10-23 10:22:37.867: E/AndroidRuntime(21490):    at android.view.View.performClick(View.java:4211)
10-23 10:22:37.867: E/AndroidRuntime(21490):    at android.view.View$PerformClick.run(View.java:17267)
10-23 10:22:37.867: E/AndroidRuntime(21490):    at android.os.Handler.handleCallback(Handler.java:615)
10-23 10:22:37.867: E/AndroidRuntime(21490):    at android.os.Handler.dispatchMessage(Handler.java:92)
10-23 10:22:37.867: E/AndroidRuntime(21490):    at android.os.Looper.loop(Looper.java:137)
10-23 10:22:37.867: E/AndroidRuntime(21490):    at android.app.ActivityThread.main(ActivityThread.java:4898)
10-23 10:22:37.867: E/AndroidRuntime(21490):    at java.lang.reflect.Method.invokeNative(Native Method)
10-23 10:22:37.867: E/AndroidRuntime(21490):    at java.lang.reflect.Method.invoke(Method.java:511)
10-23 10:22:37.867: E/AndroidRuntime(21490):    at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:1006)
10-23 10:22:37.867: E/AndroidRuntime(21490):    at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:773)
10-23 10:22:37.867: E/AndroidRuntime(21490):    at dalvik.system.NativeStart.main(Native Method)
10-2310:22:37.867:E/AndroidRuntime(21490):致命异常:main
10-23 10:22:37.867:E/AndroidRuntime(21490):android.os.NetworkOnMainThreadException
10-23 10:22:37.867:E/AndroidRuntime(21490):在android.os.StrictMode$AndroidBlockGuardPolicy.onNetwork(StrictMode.java:1118)
10-23 10:22:37.867:E/AndroidRuntime(21490):在libcore.io.BlockGuardOs.connect(BlockGuardOs.java:84)上
10-23 10:22:37.867:E/AndroidRuntime(21490):在libcore.io.IoBridge.connecterno(IoBridge.java:127)
10-23 10:22:37.867:E/AndroidRuntime(21490):在libcore.io.IoBridge.connect(IoBridge.java:112)上
10-23 10:22:37.867:E/AndroidRuntime(21490):位于java.net.PlainSocketImpl.connect(PlainSocketImpl.java:192)
10-23 10:22:37.867:E/AndroidRuntime(21490):位于java.net.PlainSocketImpl.connect(PlainSocketImpl.java:459)
10-23 10:22:37.867:E/AndroidRuntime(21490):在java.net.Socket.connect(Socket.java:842)上
10-23 10:22:37.867:E/AndroidRuntime(21490):在libcore.net.http.HttpConnection.(HttpConnection.java:76)
10-23 10:22:37.867:E/AndroidRuntime(21490):在libcore.net.http.HttpConnection.(HttpConnection.java:50)
10-23 10:22:37.867:E/AndroidRuntime(21490):在libcore.net.http.HttpConnection$Address.connect(HttpConnection.java:340)
10-23 10:22:37.867:E/AndroidRuntime(21490):在libcore.net.http.HttpConnectionPool.get(HttpConnectionPool.java:87)
10-23 10:22:37.867:E/AndroidRuntime(21490):在libcore.net.http.HttpConnection.connect(HttpConnection.java:128)上
10-23 10:22:37.867:E/AndroidRuntime(21490):位于libcore.net.http.HttpEngine.openSocketConnection(HttpEngine.java:315)
10-23 10:22:37.867:E/AndroidRuntime(21490):在libcore.net.http.HttpEngine.connect(HttpEngine.java:310)上
10-23 10:22:37.867:E/AndroidRuntime(21490):位于libcore.net.http.HttpEngine.sendSocketRequest(HttpEngine.java:289)
10-23 10:22:37.867:E/AndroidRuntime(21490):位于libcore.net.http.HttpEngine.sendRequest(HttpEngine.java:239)
10-23 10:22:37.867:E/AndroidRuntime(21490):在libcore.net.http.HttpURLConnectionImpl.connect(HttpURLConnectionImpl.java:80)
10-23 10:22:37.867:E/AndroidRuntime(21490):在de.isogon.kalepro.activities.Booklist$2.onDownload(Booklist.java:194)
10-23 10:22:37.867:E/AndroidRuntime(21490):在de.isogon.kalepro.views.dialogs.DialogDownload$2.onClick(DialogDownload.java:76)
10-23 10:22:37.867:E/AndroidRuntime(21490):在android.view.view.performClick(view.java:4211)
10-23 10:22:37.867:E/AndroidRuntime(21490):在android.view.view$PerformClick.run(view.java:17267)
10-23 10:22:37.867:E/AndroidRuntime(21490):在android.os.Handler.handleCallback(Handler.java:615)上
10-23 10:22:37.867:E/AndroidRuntime(21490):位于android.os.Handler.dispatchMessage(Handler.java:92)
10-23 10:22:37.867:E/AndroidRuntime(21490):在android.os.Looper.loop(Looper.java:137)
10-23 10:22:37.867:E/AndroidRuntime(21490):位于android.app.ActivityThread.main(ActivityThread.java:4898)
10-23 10:22:37.867:E/AndroidRuntime(21490):位于java.lang.reflect.Method.Invokenactive(本机方法)
10-23 10:22:37.867:E/AndroidRuntime(21490):在java.lang.reflect.Method.invoke(Method.java:511)
10-23 10:22:37.867:E/AndroidRuntime(21490):在com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:1006)
10-23 10:22:37.867:E/AndroidRuntime(21490):在com.android.internal.os.ZygoteInit.main(ZygoteInit.java:773)
10-23 10:22:37.867:E/AndroidRuntime(21490):在dalvik.system.NativeStart.main(本机方法)
其中de.isogon.kalepro.activities.Booklist$2.onDownload(Booklist.java:194)链接到connection.connect();上面代码的一部分

我的清单权限如下所示:

<uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE" />
<uses-permission android:name="android.permission.GET_TASKS"/>
<uses-permission android:name="android.permission.INTERNET"/>
<uses-permission android:name="android.permission.ACCESS_NETWORK_STATE" />
<uses-permission android:name="android.permission.READ_PHONE_STATE" />


我已经测试了很多下载的代码示例-所有这些示例似乎都产生了几乎相同的错误。

我使用这个类

public class ZipUtility {
    public static final void zipDirectory(File directory, File zip)
            throws IOException {
        ZipOutputStream zos = new ZipOutputStream(new FileOutputStream(zip));
        zip(directory, directory, zos);
        zos.close();
    }

    private static final void zip(File directory, File base, ZipOutputStream zos)
            throws IOException {
        File[] files = directory.listFiles();
        byte[] buffer = new byte[8192];
        int read = 0;
        for (int i = 0, n = files.length; i < n; i++) {
            if (files[i].isDirectory()) {
                zip(files[i], base, zos);
            } else {
                FileInputStream in = new FileInputStream(files[i]);
                ZipEntry entry = new ZipEntry(files[i].getPath().substring(
                        base.getPath().length() + 1));
                zos.putNextEntry(entry);
                while (-1 != (read = in.read(buffer))) {
                    zos.write(buffer, 0, read);
                }
                in.close();
            }
        }
    }

    public static final void unzip(File zip, File extractTo) throws IOException {
        ZipFile archive = new ZipFile(zip);
        Enumeration e = archive.entries();
        while (e.hasMoreElements()) {
            ZipEntry entry = (ZipEntry) e.nextElement();
            File file = new File(extractTo, entry.getName());
            if (entry.isDirectory() && !file.exists()) {
                file.mkdirs();
            } else {
                if (!file.getParentFile().exists()) {
                    file.getParentFile().mkdirs();
                }

                InputStream in = archive.getInputStream(entry);
                BufferedOutputStream out = new BufferedOutputStream(
                        new FileOutputStream(file));

                byte[] buffer = new byte[8192];
                int read;

                while (-1 != (read = in.read(buffer))) {
                    out.write(buffer, 0, read);
                }

                in.close();
                out.close();
            }
        }
    }
}
公共类可计算性{
公共静态最终void zipDirectory(文件目录,文件zip)
抛出IOException{
ZipOutputStream zos=newzipoutpstream(newfileoutputstream(zip));
zip(目录,目录,zos);
zos.close();
}
私有静态最终void zip(文件目录、文件库、ZipoutStream zos)
抛出IOException{
File[]files=目录.listFiles();
字节[]缓冲区=新字节[8192];
int read=0;
for(int i=0,n=files.length;i