Android: "Fin de secuencia inesperada" excepción descargar archivos grandes
Estoy construyendo una aplicación para Android y necesito descargar un archivo de una url, que es de 33 MB de gran tamaño.
Aquí la tarea de descarga:
- Leer correos electrónicos de Gmail con SDK de Android
- Descomprimir un archivo zip ... Archivo no encontrado excepción
- Java.lang.NoClassDefFoundError: com / android / utils / ILogger en Visual Studio 2015
- Llame a onSaveInstanceState sin llamar a super.onSaveInstanceState (outState)
- Cómo seleccionar el video de la galería y recortar / cambiar el tamaño, al igual que el recorte de imágenes en android
try { int MAX_BUFFER_SIZE = 4096; URL mUrl = new URL(params[0]); HttpURLConnection connection = (HttpURLConnection) mUrl.openConnection(); connection.setRequestMethod("GET"); long length = connection.getContentLength(), downloaded = 0; int read; byte [] buffer = new byte[(((int)length) > MAX_BUFFER_SIZE) ? MAX_BUFFER_SIZE : (int)length]; String filename = getFilename(mUrl); File file = new File (SDCARD_ROOT); if (!file.exists() || !file.isDirectory()){ file.mkdir(); } this.filename = filename; file = new File (SDCARD_ROOT + this.filename); FileOutputStream fos = new FileOutputStream (file); //Start downloading InputStream stream = connection.getInputStream(); while ((read=stream.read(buffer)) > -1){ fos.write(buffer, 0, read); downloaded += read; publishProgress((int) ((float) downloaded/length * 100)); } fos.close(); return 1; } catch (Exception e){ Log.e("REV-PARTS", "Revolver parts error in DownloadTask: " + e.getMessage()); return 2; }
Funciona a la derecha con archivos pequeños (1-15 mb), pero devolverá una excepción "inesperado final de secuencia" con archivos grandes. Gracias por adelantado.
- Objeto de matriz Iterate JSON
- Cambio de Divisas Altorithm (Android / Java / Pseudocódigo)
- Descarga rápidamente mapas de bits de la memoria
- Selector de color de Android para incluirlo en la actividad
- Android Start_redeliver_intent tarda mucho tiempo (horas) en reiniciar el servicio
- ¿Cómo se determina la latencia de audio (AudioTrack) en Android?
- Java (Android) reordenando una lista de objetos
- ¿Qué es una buena práctica para combinar sus clases?
Tengo una respuesta para esto. Debe agregar un encabezado a su conexión.
connection.setRequestProperty("Accept-Encoding", "identity");
Esto te ayudará. Dime si ayuda …
Para archivos grandes debe establecer el tiempo de espera de conexión manualmente utilizando el código siguiente. He fijado el tiempo a 3 minutos
connection.setConnectTimeout(180000); connection.setReadTimeout(180000);
Mientras que usted coge la excepción, intento el método downContinue (), puedo mostrar mi código:
private void downloadApk() { thread1 = new Thread() { public void run() { File oFile = null; try { URL url = new URL(PQGLApplication.resrootURL + "apk/PQGLMap.apk"); HttpURLConnection urlConnection = (HttpURLConnection) url.openConnection(); ReadableByteChannel channel = Channels.newChannel(urlConnection.getInputStream()); oFile = new File(Environment.getExternalStorageDirectory().getAbsolutePath() + "/" + "hy_ht_new/" + "test2" + ".apk"); oFile.setWritable(true); oFile.setReadable(true); if (oFile.exists()) { oFile.delete(); } FileOutputStream fos = new FileOutputStream(oFile); fileSize = urlConnection.getContentLength(); ByteBuffer buffer = ByteBuffer.allocate(1024); int noOfBytes = 0; byte[] data = null; sendApkMessage(0, 0); while ((noOfBytes = channel.read(buffer)) > 0) { data = new byte[noOfBytes]; System.arraycopy(buffer.array(), 0, data, 0, noOfBytes); buffer.clear(); fos.write(data, 0, noOfBytes); downLoadFileSize += noOfBytes; sendApkMessage(1, downLoadFileSize); } fos.flush(); fos.close(); channel.close(); sendApkMessage(2, oFile.getAbsolutePath()); } catch (Exception e) { // TODO Auto-generated catch block e.printStackTrace(); downContinue(); } }; }; thread1.start(); } private void downContinue() { continueTime++; try { if (continueTime == 3) { continueTime = 0; sendApkMessage(4, 0); Log.e("what is the fucking continuetime", "continueTime" + continueTime); } else { URL url = new URL(PQGLApplication.resrootURL + "apk/PQGLMap.apk"); HttpURLConnection urlConnection = (HttpURLConnection) url.openConnection(); File oFile = new File(Environment.getExternalStorageDirectory().getAbsolutePath() + "/" + "hy_ht_new/" + "test2" + ".apk"); RandomAccessFile oSavedFile = new RandomAccessFile(oFile, "rw"); FileOutputStream fos = new FileOutputStream(oFile); ReadableByteChannel channel = Channels.newChannel(urlConnection.getInputStream()); // oSavedFile.seek(nPos); ByteBuffer buffer = ByteBuffer.allocate(1024); byte[] data = null; int temp = 0; sendApkMessage(3, oFile.getAbsolutePath()); while ((temp = channel.read(buffer)) > 0) { data = new byte[temp]; System.arraycopy(buffer.array(), 0, data, 0, temp); buffer.clear(); fos.write(data, 0, temp); } fos.flush(); fos.close(); oSavedFile.close(); sendApkMessage(2, oFile.getAbsolutePath()); continueTime = 0; } } catch (Exception e) { // TODO Auto-generated catch block e.printStackTrace(); Log.e("what is the fucking exception", e.toString() + continueTime); downContinue(); } }
Este método downContinue se utiliza para resolver este problema. ¡Por lo menos, el archivo se descarga con éxito! Vengo de China.Mi inglés no es tan bueno.
- EditText en ListView es actualizado por onTextChanged al desplazarse
- Ocultar teclado virtual al hacer clic en un botón