12

インターネットから大きなファイル (>20Mb) をダウンロードしようとしています

private class DownloadTask extends AsyncTask<DatabaseInfo, Integer, String> {

    private DatabaseInfo info;

    protected String doInBackground(DatabaseInfo... dbInfo) {

        int count;
        info = dbInfo[0];

        try {

            URL url = new URL(dbInfo[0].dbPath);

            InputStream input = new BufferedInputStream(url.openStream());
            OutputStream output = new FileOutputStream("/sdcard/db.zip");

            byte data[] = new byte[1024];
            int total = 0;

            while ((count = input.read(data)) != -1) {

                //output.write(data, 0, count);

                total += count;

                if (total % 10240 == 0) {
                    publishProgress(total);
                }
            }

            output.flush();
            output.close();
            input.close();
        } 
        catch (Exception e) {
            Log.e("err", e.getMessage());
        }

        return null;
    }

    protected void onProgressUpdate(Integer... total) {

        int perc = (int) ((float) total[0] / (float) info.dbZipSize * 100);
        mProgressDialog.setProgress(perc);
    }

    protected void onPostExecute(String s) {

        dismissDialog(DIALOG_PROGRESS);
        Log.e("err", "finish!");
    }
}

行のコメントを外すと

//output.write(data, 0, count);

ダウンロードの 7 ~ 15% 後、プログレスバーのダイアログが閉じ、「完了!」と表示されます。ログで。なんで?

4

2 に答える 2

6

HTTP 範囲の実装を検討する必要があります。これにより、ダウンロードが失敗したときにダウンロードを再開できます。

停止する理由については、一部の通信事業者はダウンロード制限を実装しており、一定の時間またはダウンロード量が経過すると接続が切断されます。私はこれをある英国の通信事業者で直接見たことがあり、他の通信事業者でそれについて話されました. 通常、Android ブラウザ経由でファイルをダウンロードしてみて、制限を確認するのは簡単です。ファイルが停止または停止した場合は、キャリアの問題である可能性が高いことがわかります (もちろん、ダウンロードは例外をスローせずに終了できます)。

Http Range の実​​装により、中断したところからダウンロードを続行できるため、doInBackground メソッドでホールドオフと再開アルゴリズムを使用して、接続が中断されるたびに一定時間待ってから再開しようとすることができます。ダウンロードは中断されます (もちろん、電話が実際にファイルをダウンロードできないときに無限ループに陥らないように、再試行制限を実装します)。

于 2010-07-01T07:48:46.357 に答える