Android 将高达50MB的视频上载到服务器
我想将视频从android应用程序上载到服务器。当我尝试上载视频时,我的应用程序显示Android 将高达50MB的视频上载到服务器,android,Android,我想将视频从android应用程序上载到服务器。当我尝试上载视频时,我的应用程序显示04-23 13:07:41.602:ERROR/dalvikvm heap(519):15607356字节分配的内存不足。我不知道为什么会发生错误。我的问题是 我们可以使用下面的代码上传大小不超过50MB的视频吗?如果有人知道,请帮助我… private void doFileUpload(){ HttpURLConnection conn = null; Dat
04-23 13:07:41.602:ERROR/dalvikvm heap(519):15607356字节分配的内存不足。
我不知道为什么会发生错误。我的问题是
我们可以使用下面的代码上传大小不超过50MB的视频吗?如果有人知道,请帮助我…private void doFileUpload(){
HttpURLConnection conn = null;
DataOutputStream dos = null;
DataInputStream inStream = null;
String lineEnd = "\r\n";
String twoHyphens = "--";
String boundary = "*****";
int bytesRead, bytesAvailable, bufferSize;
byte[] buffer;
int maxBufferSize = 8*1024*1024;
Cursor c = (MainscreenActivity.JEEMAHWDroidDB).query((MainscreenActivity.TABLE_Name), new String[] {
(MainscreenActivity.COL_HwdXml)}, null, null, null, null,
null);
if(c.getCount()!=0){
c.moveToLast();
for(int i=c.getCount()-1; i>=0; i--) {
value=c.getString(0);
}
}
String urlString = value+"/upload_file.php";
try
{
//------------------ CLIENT REQUEST
UUID uniqueKey = UUID.randomUUID();
fname = uniqueKey.toString();
Log.e("UNIQUE NAME",fname);
FileInputStream fileInputStream = new FileInputStream(new File(selectedPath) );
URL url = new URL(urlString);
conn = (HttpURLConnection) url.openConnection();
conn.setDoInput(true);
conn.setDoOutput(true);
conn.setUseCaches(false);
conn.setRequestMethod("POST");
conn.setRequestProperty("Connection", "Keep-Alive");
conn.setRequestProperty("Content-Type", "multipart/form-data;boundary="+boundary);
dos = new DataOutputStream( conn.getOutputStream() );
dos.writeBytes(twoHyphens + boundary + lineEnd);
dos.writeBytes("Content-Disposition: form-data; name=\"uploadedfile\";filename=\"" + fname + "."+extension+"" + lineEnd);
dos.writeBytes(lineEnd);
bytesAvailable = fileInputStream.available();
System.out.println("BYTES:--------->"+bytesAvailable);
bufferSize = Math.min(bytesAvailable, maxBufferSize);
System.out.println("BUFFER SIZE:--------->"+bufferSize);
buffer = new byte[bufferSize];
System.out.println("BUFFER:--------->"+buffer);
bytesRead = fileInputStream.read(buffer,0,bufferSize);
System.out.println("BYTES READ:--------->"+bytesRead);
while (bytesRead > 0)
{
dos.write(buffer, 0, bufferSize);
bytesAvailable = fileInputStream.available();
bufferSize = Math.min(bytesAvailable, maxBufferSize);
bytesRead = fileInputStream.read(buffer, 0, bufferSize);
System.out.println("RETURNED");
}
dos.writeBytes(lineEnd);
dos.writeBytes(twoHyphens + boundary + twoHyphens + lineEnd);
Log.e("Debug","File is written");
fileInputStream.close();
dos.flush();
dos.close();
}
catch (MalformedURLException ex)
{
Log.e("Debug", "error: " + ex.getMessage(), ex);
}
catch (IOException ioe)
{
Log.e("Debug", "error: " + ioe.getMessage(), ioe);
}
//------------------ read the SERVER RESPONSE
try {
inStream = new DataInputStream ( conn.getInputStream() );
String str;
while (( str = inStream.readLine()) != null)
{
Log.e("Debug","Server Response "+str);
}
inStream.close();
}
catch (IOException ioex){
Log.e("Debug", "error: " + ioex.getMessage(), ioex);
}
也就是说,内存不足。尝试通过减少缓冲区大小来减少我的内存使用:
int maxBufferSize = 2*1024*1024;
也就是说,内存不足。尝试通过减少缓冲区大小来减少我的内存使用:
int maxBufferSize = 2*1024*1024;
试着替换
bytesAvailable = fileInputStream.available();
System.out.println("BYTES:--------->"+bytesAvailable);
bufferSize = Math.min(bytesAvailable, maxBufferSize);
System.out.println("BUFFER SIZE:--------->"+bufferSize);
buffer = new byte[bufferSize];
System.out.println("BUFFER:--------->"+buffer);
bytesRead = fileInputStream.read(buffer,0,bufferSize);
System.out.println("BYTES READ:--------->"+bytesRead);
while (bytesRead > 0)
{
dos.write(buffer, 0, bufferSize);
bytesAvailable = fileInputStream.available();
bufferSize = Math.min(bytesAvailable, maxBufferSize);
bytesRead = fileInputStream.read(buffer, 0, bufferSize);
System.out.println("RETURNED");
}
与
解释:将返回它读取的字节数或-1
,如果到达流的末尾并且无法读取更多数据。它还使用读取的数据填充缓冲区的前N个字节。(a=b)!=c
语法首先将b赋值给a,然后将值与c进行比较(此处:执行read
,将结果赋值给bytesRead
,比较-1
)。因此,循环一直运行,直到从流的开始到结束读取每个字节为止
每次读取
后,通过写入缓冲区中的数据。由于我们从bytesRead
中知道buffer
中有多少字节实际上是新读取的字节,我们告诉write
只写入0
到bytesRead
的字节。无需检查InputStream.available()
(如果流的长度未知,甚至可能返回无意义的结果)或任何其他方法
注意:将其更改为while(bytesRead>0)
会带来细微的差异。如果您读取了0个字节,但未到达流的结尾,它将停止读取。这起案件是合法的,尽管假设它不会发生是相当安全的。如果您使用bytesRead>=0,则会更安全。尝试更换
bytesAvailable = fileInputStream.available();
System.out.println("BYTES:--------->"+bytesAvailable);
bufferSize = Math.min(bytesAvailable, maxBufferSize);
System.out.println("BUFFER SIZE:--------->"+bufferSize);
buffer = new byte[bufferSize];
System.out.println("BUFFER:--------->"+buffer);
bytesRead = fileInputStream.read(buffer,0,bufferSize);
System.out.println("BYTES READ:--------->"+bytesRead);
while (bytesRead > 0)
{
dos.write(buffer, 0, bufferSize);
bytesAvailable = fileInputStream.available();
bufferSize = Math.min(bytesAvailable, maxBufferSize);
bytesRead = fileInputStream.read(buffer, 0, bufferSize);
System.out.println("RETURNED");
}
与
解释:将返回它读取的字节数或-1
,如果到达流的末尾并且无法读取更多数据。它还使用读取的数据填充缓冲区的前N个字节。(a=b)!=c
语法首先将b赋值给a,然后将值与c进行比较(此处:执行read
,将结果赋值给bytesRead
,比较-1
)。因此,循环一直运行,直到从流的开始到结束读取每个字节为止
每次读取
后,通过写入缓冲区中的数据。由于我们从bytesRead
中知道buffer
中有多少字节实际上是新读取的字节,我们告诉write
只写入0
到bytesRead
的字节。无需检查InputStream.available()
(如果流的长度未知,甚至可能返回无意义的结果)或任何其他方法
注意:将其更改为while(bytesRead>0)
会带来细微的差异。如果您读取了0个字节,但未到达流的结尾,它将停止读取。这起案件是合法的,尽管假设它不会发生是相当安全的。如果使用bytesRead>=0,则更安全。即使使用此代码,也会出现相同的错误“内存不足”。在这种情况下,您应该使用httppost和多部分实体来发布数据…即使使用此代码,也会出现相同的错误“内存不足”在这种情况下,您应该使用httppost和multipart entity发布数据…如果我们减小缓冲区大小,我们可以上传高达50MB的视频吗?我仍然会遇到相同的错误。您能帮我修复错误吗?@sundar buffersize应该更像8kb(8*1024)-你不需要一个巨大的缓冲区,尤其是在连接速度较慢的情况下。如果我们减小缓冲区大小,我们可以上传高达50MB的视频吗?我仍然会遇到同样的错误。你能帮我修复这个错误吗?@sundar buffersize应该更像8kb(8*1024)-你不需要一个巨大的缓冲区,特别是当它是一个慢速连接时。我减少了maxBuffersize,但我在上传时仍然收到相同的错误。它的强制关闭我的活动我的应用上传高达4.1MB,如果我尝试上传的内容超过这个,我的应用强制关闭。这里发生了什么pblm?我对此一无所知。如果有人知道我减少了maxBuffersize,请帮助我,但我在上传时仍然收到相同的错误。它的强制关闭了我的活动我的应用上传高达4.1MB,如果我尝试上传的内容超过此数,我的应用将强制关闭。这里发生了什么pblm?我对此一无所知。如果有人知道,请帮助我谢谢!!但是while循环中的一个小变化“while((bytesRead=fileInputStream.read(buffer))>0{dos.write(buf,0,bytesRead);}”添加了一些解释,while循环几乎是标准的流复制模式&你可以在互联网上找到它。谢谢!!但是while循环中的一个小变化“while((bytesRead=fileInputStream.read(buffer))>0{dos.write(buf,0,bytesRead);}”添加了一些解释,while循环几乎是标准的流复制模式&你可以在互联网上找到它。