公開しているアプリでタイトルの不具合が発生し困っています。
もし原因または解決方法をご存知でしたらご意見をお聞かせください。
Exceptionは下記の通りです。
java.io.FileNotFoundException /storage/emulated/0/Android/data/jp.co.sample/files/Download/samples/test.zip: open failed: ENOENT (No such file or directory) raw
不具合が発生しているのは下記の端末でいずれもFujitsuのAndroid OS 5.X系です。手持ちの端末では再現しません。
- RM02
- M02
- F02G
不具合発生までの流れはこちらです。
- サーバーよりZIPファイルのURIを取得
- DownloadManagerに対象のURIからのダウンロードをリクエスト
- ダウンロード完了のコールバックを受け取り保存ファイルの解凍を行う←不具合発生
ソースは少し簡略化しました。
ダウンロード完了のBroadcastReceiverは登録済みとします。
Java
1 2long targetDownloadId; 3String fileName; 4 5private void downloadZippedFile() { 6 // ダウンロードマネージャーに渡すリクエストを作成 7 DownloadManager.Request request = new DownloadManager.Request(uri); 8 9 // ダウンロードにデータ通信とWi-Fi通信の使用を許可する 10 request.setAllowedNetworkTypes( 11 DownloadManager.Request.NETWORK_MOBILE | DownloadManager.Request.NETWORK_WIFI); 12 13 request.setDestinationInExternalFilesDir( 14 context, 15 Environment.DIRECTORY_DOWNLOADS + "/samples", 16 "test.zip" 17 ); 18 19 targetDownloadId = mDownloadManager.enqueue(request); 20} 21 22private BroadcastReceiver onDownloadComplete = new BroadcastReceiver() { 23 @Override 24 public void onReceive(Context paramContext, Intent paramIntent) { 25 long downloadId = paramIntent.getLongExtra(DownloadManager.EXTRA_DOWNLOAD_ID, 0); 26 27 if (downloadId != 0 && targetDownloadId == downloadId) { 28 29 boolean isDownloadSuccess = false; 30 31 // ダウンロードステータスの確認 32 DownloadManager.Query query = new DownloadManager.Query(); 33 query.setFilterById(targetMapInfo.downloadId); 34 Cursor c = mDownloadManager.query(query); 35 if (c.moveToFirst()) { 36 int statusColumn = c.getColumnIndex(DownloadManager.COLUMN_STATUS); 37 38 if (DownloadManager.STATUS_SUCCESSFUL == c.getInt(statusColumn)) { 39 isDownloadSuccess = true; 40 int localFileNameColumn = c.getColumnIndex(DownloadManager.COLUMN_LOCAL_FILENAME); 41 fileName = c.getString(localFileNameColumn); 42 } 43 } 44 45 if (isDownloadSuccess) { 46 // 成功 47 unzip(); 48 } 49 } 50 } 51}; 52 53private void unzipMap() { 54 File filePath = new File(fileName); 55 56 // Zipファイルを開く !ここで発生 57 ZipInputStream zipInputStream = new ZipInputStream(new BufferedInputStream(new FileInputStream(filePath))); 58} 59
あなたの回答
tips
プレビュー