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.