当前位置: 首页 > 编程笔记 >

Android Volley扩展实现支持进度条的文件上传功能

西门安民
2023-03-14
本文向大家介绍Android Volley扩展实现支持进度条的文件上传功能,包括了Android Volley扩展实现支持进度条的文件上传功能的使用技巧和注意事项,需要的朋友参考一下

volley是一个轻量级的开源网络通信框架,开源的好处就是可以自由定制自己需要的jar包。volley里网络通信时android2.3以上用的HttpUrlConnection,2.3以下用的HttpClient,我做的改动只考虑了2.3以上,不支持2.3版本以下。HttpUrlConnection默认传输数据是将数据全部写到内存中再发送到服务端,Volley就是采用默认的方式,这样在上传大文件时很容易就out of memory,有一种解决办法是设置每次传输流的大小:

已知文件大小:connection .setFixedLengthStreamingMode(long l);

不知道文件大小:connection.setChunkedStreamingMode(1024); //建议使用

android的文件上传一般都是模拟表单,也可以直接socket传,我这里是集成了表单上传,下面是关键类:

public class MultipartRequest extends Request<String> {
 private final Listener<String> mListener;
 private Map<String, String> headerMap;
 private Map<String, String> mParams;
 private FormFile[] files;
 private String BOUNDARY = "---------7dc05dba8f3e19";
 
 public MultipartRequest(String url, Listener<String> listener, Map<String, String> params, FormFile[] files) {
 this(Method.POST, url, listener, params, files);
 }
 
 public MultipartRequest(int method, String url, Listener<String> listener, Map<String, String> params, FormFile[] files) {
 super(method, url, listener);
 mListener = listener;
 mParams = params;
 this.files = files;
 }
 
 @Override
 public Map<String, String> getHeaders() throws AuthFailureError {
 headerMap = new HashMap<String, String>();
 headerMap.put("Charset", "UTF-8");
 //Keep-Alive
 headerMap.put("Connection", "Keep-Alive");
 headerMap.put("Content-Type", "multipart/form-data; boundary=" + BOUNDARY);
 return headerMap;
 }
 
 @Override
 public byte[] getBody() throws AuthFailureError {
 //传参数
 StringBuilder sb = new StringBuilder();
 for (Map.Entry<String, String> entry : mParams.entrySet()) {
  // 构建表单字段内容
  sb.append("--");
  sb.append(BOUNDARY);
  sb.append("\r\n");
  sb.append("Content-Disposition: form-data; name=\"" + entry.getKey() + "\"\r\n\r\n");
  sb.append(entry.getValue());
  sb.append("\r\n");
 }
 return sb.toString().getBytes();
 }
 
 @Override
 public void handRequest(OutputStream out) {
 DataOutputStream dos = (DataOutputStream) out;
 try {
  //发送文件数据
  if (files != null) {
  for (FormFile file : files) {
   // 发送文件数据
   StringBuilder split = new StringBuilder();
   split.append("--");
   split.append(BOUNDARY);
   split.append("\r\n");
   split.append("Content-Disposition: form-data;name=\"" + file.getParameterName() + "\";filename=\"" + file.getFilname() + "\"\r\n");
   split.append("Content-Type: " + file.getContentType() + "\r\n\r\n");
   dos.write(split.toString().getBytes());
   if (file.getInStream() != null) {
   byte[] buffer = new byte[1024];
   int len = -1;
   int count = 0;
   while ((len = file.getInStream().read(buffer)) != -1) {
    dos.write(buffer, 0, len);
    count += len;
    if (mListener != null) {
    mListener.onProgressChange(file.getFileSize(), count);
    }
   }
   count = 0;
   file.getInStream().close();
   } else {
   dos.write(file.getData(), 0, file.getData().length);
   }
   dos.write("\r\n".getBytes());
  }
  }
  dos.writeBytes("--" + BOUNDARY + "--\r\n");
  dos.flush();
 } catch (IOException e) {
  mListener.onError(new VolleyError(e.toString()));
  try {
  dos.close();
  } catch (IOException e1) {
  e1.printStackTrace();
  }
 }
 }
 
 @Override
 protected Response<String> parseNetworkResponse(NetworkResponse response) {
 String parsed;
 try {
  parsed = new String(response.data, HttpHeaderParser.parseCharset(response.headers));
 } catch (UnsupportedEncodingException e) {
  parsed = new String(response.data);
 }
 return Response.success(parsed, HttpHeaderParser.parseCacheHeaders(response));
 }
 
 @Override
 protected void deliverResponse(String response) {
 mListener.onSuccess(response);
 }
 
 @Override
 public void deliverError(VolleyError error) {
 mListener.onError(error);
 }
}

附上demo连接:Android实现文件上传功能

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持小牛知识库。

 类似资料:
  • 本文向大家介绍Vue实现带进度条的文件拖动上传功能,包括了Vue实现带进度条的文件拖动上传功能的使用技巧和注意事项,需要的朋友参考一下 1. 基本界面 2. 检测拖动事件 首先让页面支持文件拖拽,在 Vue 的 mounted() 函数中添加代码: 当把文件拖动到浏览器的拖动区域时,会触发三种事件: 文件第一次进入拖动区时,触发 dragenter 事件 文件在拖动区来回拖拽时,不断触发 drag

  • 本文向大家介绍jQuery插件实现文件上传功能(支持拖拽),包括了jQuery插件实现文件上传功能(支持拖拽)的使用技巧和注意事项,需要的朋友参考一下 先贴上源代码地址,点击获取。然后直接进入主题啦,当然,如果你觉得我有哪里写的不对或者欠妥的地方,欢迎留言指出。在附上一些代码之前,我们还是先来了解下,上传文件的时候需要利用的一些必要的知识。  首先我们要说的就是FileReader对象,这是一个H

  • 本文向大家介绍jQuery实现文件上传进度条特效,包括了jQuery实现文件上传进度条特效的使用技巧和注意事项,需要的朋友参考一下 上传进度条通常是由前面jquery加后端了脚本器脚本来实现了,今天我们介绍的是一款基本php+jQuery实现文件上传进度条效果的例子,具体细节如下。 最近呢,一个项目做一个进度条的效果出来,这个之前还真没做过。刚好这周没什么东西了,就拿这个来充一下数吧。 文件上传,

  • 本文向大家介绍Node.js实现兼容IE789的文件上传进度条,包括了Node.js实现兼容IE789的文件上传进度条的使用技巧和注意事项,需要的朋友参考一下 Nodejs对文件上传的处理 在Express4里req.files已经是undefined了;现在用的最多的可能就是formidable了,你知道了它有个progress事件,于是心中大喜,低版本IE的进度条有戏了;OK,试一下: 是的,

  • 本文向大家介绍axios+Vue实现上传文件显示进度功能,包括了axios+Vue实现上传文件显示进度功能的使用技巧和注意事项,需要的朋友参考一下 一,前言 最近在用Vue,然后上传文件时需要显示进度,于是网上搜了一下,经过自己实测终于也弄明白了 二,效果 三,代码 HTML代码 CSS代码 JS代码  四,总结 1.其实单文件上传和多文件上传的区别就是 input标签中多了一个属性 multip

  • 本文向大家介绍php使用APC实现实时上传进度条功能,包括了php使用APC实现实时上传进度条功能的使用技巧和注意事项,需要的朋友参考一下 php不具备实时上传进度条功能,如果想有这种功能我们一般会使用ajax来实现,但是php提供了一个apc,它就可以与php配置实现上传进度条功能。 主要针对的是window上的应用。 1.服务器要支持apc扩展,没有此扩展的话,下载一个扩展扩展要求php.5.