Android Large Video Upload auf den Server?
Android große Video-Upload auf PHP-Server, las ich viele Antworten im Stackoverflow.
Hochladen von Videos bis zu 50 MB auf den Server
Android: OutOfMemoryError beim Hochladen von Videos - wie am besten zu chunk?
Wie kann ich eine HTTP-POST-Anfrage senden und eine Antwort erhalten?
Ich habe es ausprobiert, kann aber nicht einmal für mich arbeitensetChunkedStreamingMode()
..Wenn ich ein Video hochlade, gib es mirOutOfMemoryError
Wenn ich Video 5 Sekunden aufnehme, funktioniert es gut, aber mehr als 8 oder 10 Sekunden Video-App-Kraft schließen aufgrundOutOfMemoryError
MEIN CODE ::
HttpClient httpclient = new DefaultHttpClient();
HttpPost httppost = new HttpPost(getString(R.string.login_url)
+ "uploadvideo");
HttpResponse response = null;
InputStream inputStream = getContentResolver().openInputStream(
Uri.fromFile(myFile));
byte[] data = IOUtils.toByteArray(inputStream);
String type = getFileExtension(myFile.getName().toString());
String encodeurl = Base64.encodeBytes(data);
try {
List<NameValuePair> nameValuePairs = new ArrayList<NameValuePair>(
6);
nameValuePairs.add(new BasicNameValuePair("returnformat",
"json"));
nameValuePairs.add(new BasicNameValuePair("userid",
strUserid));
nameValuePairs.add(new BasicNameValuePair("video",
data.toString()));
nameValuePairs.add(new BasicNameValuePair("type", type));
nameValuePairs.add(new BasicNameValuePair("title",
strVideoName));
nameValuePairs.add(new BasicNameValuePair("description",
strVideoComments));
httppost.setEntity(new UrlEncodedFormEntity(nameValuePairs));
// Execute HTTP Post Request
response = httpclient.execute(httppost);
System.out.println(">>>>>>>>>>" + response.toString());
} catch (ClientProtocolException e) {
e.printStackTrace();
} catch (IOException e) {
e.printStackTrace();
}
Und ich muss ein Video hochladenBase64 Encoded String
Und ich weiß, dass Speicherfehler aufgrund von mehr Speicher als Heap-Größe. Aber ich konnte kein Video hochladen.
LOGCAT
05-31 23:16:12.114: E/AndroidRuntime(17255): java.lang.RuntimeException: An error occured while executing doInBackground()
05-31 23:16:12.114: E/AndroidRuntime(17255): at android.os.AsyncTask$3.done(AsyncTask.java:200)
05-31 23:16:12.114: E/AndroidRuntime(17255): at java.util.concurrent.FutureTask$Sync.innerSetException(FutureTask.java:274)
05-31 23:16:12.114: E/AndroidRuntime(17255): at java.util.concurrent.FutureTask.setException(FutureTask.java:125)
05-31 23:16:12.114: E/AndroidRuntime(17255): at java.util.concurrent.FutureTask$Sync.innerRun(FutureTask.java:308)
05-31 23:16:12.114: E/AndroidRuntime(17255): at java.util.concurrent.FutureTask.run(FutureTask.java:138)
05-31 23:16:12.114: E/AndroidRuntime(17255): at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1088)
05-31 23:16:12.114: E/AndroidRuntime(17255): at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:581)
05-31 23:16:12.114: E/AndroidRuntime(17255): at java.lang.Thread.run(Thread.java:1027)
05-31 23:16:12.114: E/AndroidRuntime(17255): Caused by: java.lang.OutOfMemoryError: (Heap Size=20103KB, Allocated=15700KB, Bitmap Size=0KB)
05-31 23:16:12.114: E/AndroidRuntime(17255): at java.nio.CharArrayBuffer.<init>(CharArrayBuffer.java:43)
05-31 23:16:12.114: E/AndroidRuntime(17255): at java.nio.ReadWriteCharArrayBuffer.<init>(ReadWriteCharArrayBuffer.java:47)
05-31 23:16:12.114: E/AndroidRuntime(17255): at java.nio.BufferFactory.newCharBuffer(BufferFactory.java:82)
05-31 23:16:12.114: E/AndroidRuntime(17255): at java.nio.CharBuffer.allocate(CharBuffer.java:53)
05-31 23:16:12.114: E/AndroidRuntime(17255): at java.nio.charset.CharsetDecoder.allocateMore(CharsetDecoder.java:261)
05-31 23:16:12.114: E/AndroidRuntime(17255): at java.nio.charset.CharsetDecoder.decode(CharsetDecoder.java:218)
05-31 23:16:12.114: E/AndroidRuntime(17255): at java.nio.charset.Charset.decode(Charset.java:488)
05-31 23:16:12.114: E/AndroidRuntime(17255): at java.lang.String.<init>(String.java:181)
05-31 23:16:12.114: E/AndroidRuntime(17255): at java.lang.String.<init>(String.java:141)