rxjava+retrofit实现多图上传实例代码

在看了网上多篇rxjava和retrofit的文章后,大概有了一个初步的认识,刚好要做一个多图上传的功能,就拿它开刀吧。下面的内容将基于之前实现方式和使用rxjava实现之间的异同展开,初次写笔记不喜就喷。

普通版多图上传

由于目前手机照片动辄几M的大小,如果不做处理就直接上传,我就笑笑不说话(给个眼神你自己体会)。所以,上传分为两步:对图片进行压缩和请求上传。下面请看伪代码(PS:自己不会写后台,项目后台不能拿来用,所以只能给伪代码了)

//图片集合
List<String> imgs = new ArrayList<>();
//压缩后的图片路径集合
List<String> tmpImgs = new ArrayList<>();

Handler mHandler = new Handler() {
  @Override
  public void handleMessage(Message msg) {
    super.handleMessage(msg);
    //TODO 收到消息后调用网络请求上传
  }
};

public void compressImages() {
  new Thread(new Runnable() {
    @Override
    public void run() {
      for (String path : imgs) {
        //TODO 调用压缩图片的方法,压缩后保存在一个临时文件夹中
        tmpImgs.add("压缩后路径");
      }
      mHandler.sendEmptyMessage(0);
    }
  }).start();
}

看完后是不是觉得很麻烦,好吧可能仅仅是我实现的麻烦而已。都说使用rxjava后逻辑链会变得更清晰,就看看是不是这样,下面请看用rxjava后的伪代码:

@Multipart
@POST("your address")
Observable<String> uploadImgs(@PartMap Map<String, RequestBody> map,                     @Part("imgs") MultipartBody body);

//先定义一个请求接口,除了图片可能还有其他一些参数需要上传,所以还定义了个map。接下来开始正文:

public void upload() {
  final Map<String, RequestBody> map = new HashMap<>();
  map.put("userId", RequestBody.create(MediaType.parse("form-data"),"1");
  final MultipartBody.Builder builder = new MultipartBody.Builder();
  Observable.from(imgs)
      .map(new Func1<String, String>() {
        @Override
        public String call(String path) {
          //调用图片压缩,返回压缩后路径tmp_path
          //注意,Filedata是后台给你的对应的字段
          builder.addFormDataPart("Filedata", "avatar.png", RequestBody.create(MultipartBody.FORM, new File(tmp_path)));
          return path;
        }
      }).last()
      .flatMap(new Func1<String, Observable<String>>() {
        @Override
        public Observable<String> call(String path) {
          return apiService.uploadImgs(map, builder.build());
        }
      })
      .subscribeOn(Schedulers.io())
      .observeOn(AndroidSchedulers.mainThread())
      .subscribe(new Subscriber<String>() {
        @Override
        public void onCompleted() {
        }
        @Override
        public void onError(Throwable e) {
          //错误处理
        }
        @Override
        public void onNext(String res) {
          //成功后处理
        }
      });
}

黑人问号脸?代码看起来还是很多啊,你TM在逗我。听本汪开始胡说八道:

1、首先定义个Map,这个就是用来上传其他参数用的,为什么value是RequestBody类型的,用String不就可以了吗,瞎装什么逼啊。好吧,本汪开始也是这么认为的,结果传到服务器的值自带‘'加成,传个1过去变成了‘1',正打算一本正经的找后台谈谈的,发现自己传上去的就是这样(脸红ing)。然后发现用@part注解的,如果不使用RequestBody,会自动加上‘',这点至今不知为何,还请懂的小伙伴释疑。

2、然后是MultipartBody.Builder,顾名思义,能添加多个RequestBody,用来添加多个图片。好了,小火车要开动了。

3、简单说下接下来这一大段代码是干嘛的,当然建立在你已经了解rxjava的from、map、flatmap、last是用来干嘛的基础上。

a、from会将imgs集合拆分成单个的String发送出去

b、map的作用是在此进行图片压缩,并将压缩后的图片添加到MultipartBody.Builder,相当于for循环压缩了图片。

c、flatmap这里,可谓是成败再次一举了。这里有一个转换,注意map处理后返回的String依然是一个String类型,经过flatmap后将转化为 Observable<String>,也就是我们图片上传后返回的结果。

d、好了,到此为止好像已经达到我们一条链下来就实现了图片上传的功能了,感觉是要清晰那么一点(如果没有,那我还TM瞎折腾什么)。哎,别走啊你把last忽略掉是什么鬼。

e、如果不在map后添加last方法,大家可以试一试,保证后台白眼都要翻到天上去了。由于from一个一个的发送,所以每一个对象都会在flatmap这里调用一次uploadImgs方法,这样肯定是不行了,加last方法后,只会发送发送从map出来的序列的最后一个对象,这样就保证在所有图片都压缩完成并且加入后MultipartBody.Builder后再调用uploadImgs方法,并且只会调用一次。

以上就是我用rxjava+retrofit做多图上传的小笔记,希望对大家的学习有所帮助,也希望大家多多支持我们。

(0)

相关推荐

  • Retrofit Rxjava实现图片下载、保存并展示实例

    首先我们看一下Retrofit常规的用法,在不使用Rxjava的情况下,我们默认返回的是Call. public interface ServiceApi { //下载文件 @GET Call<ResponseBody> downloadPicFromNet(@Url String fileUrl); } 但是如果我们要配合Rxjava使用,那么就要按照如下方式来重新定义我们的方法: @GET Observable<ResponseBody> downloadPicFromNet(

  • Android Retrofit和Rxjava的网络请求

    Android  Retrofit和Rxjava的网络请求 去年的时候好多公司就已经使用Rxjava和Retrofit了,最近自自己学习了一下,感觉真的是很好用,让自己的网络请求变得更简单了,而且封装性极强. 首先做一下准备工作,导入需要引用的文件 compile 'com.android.support:appcompat-v7:25.1.0' testCompile 'junit:junit:4.12' compile 'io.reactivex:rxjava:1.1.0' compile

  • Android中的Retrofit+OkHttp+RxJava缓存架构使用

    RxJava如何与Retrofit结合 先扔出build.gradle文件的内容 dependencies { compile fileTree(dir: 'libs', include: ['*.jar']) testCompile 'junit:junit:4.12' compile 'com.android.support:appcompat-v7:23.2.0' compile 'io.reactivex:rxjava:1.1.0' compile 'io.reactivex:rxand

  • RxJava2.x+ReTrofit2.x多线程下载文件的示例代码

    写在前面: 接到公司需求:要做一个apk升级的功能,原理其实很简单,百度也一大堆例子,可大部分都是用框架,要么就是HttpURLConnection,实在是不想这么干.正好看了两天的RxJava2.x+ReTrofit2.x,据说这俩框架是目前最火的异步请求框架了.固本文使用RxJava2.x+ReTrofit2.x实现多线程下载文件的功能. 如果对RxJava2.x+ReTrofit2.x不太了解的请先去看相关的文档. 大神至此请无视. 思路分析: 思路及其简洁明了,主要分为以下四步 1.获取

  • rxjava+retrofit实现多图上传实例代码

    在看了网上多篇rxjava和retrofit的文章后,大概有了一个初步的认识,刚好要做一个多图上传的功能,就拿它开刀吧.下面的内容将基于之前实现方式和使用rxjava实现之间的异同展开,初次写笔记不喜就喷. 普通版多图上传 由于目前手机照片动辄几M的大小,如果不做处理就直接上传,我就笑笑不说话(给个眼神你自己体会).所以,上传分为两步:对图片进行压缩和请求上传.下面请看伪代码(PS:自己不会写后台,项目后台不能拿来用,所以只能给伪代码了) //图片集合 List<String> imgs =

  • Kindeditor单独调用多图上传实例

    html代码: <input type="button" id="J_selectImage" value="图片上传" /> <div id="J_imageView"> <?php foreach($imgs as $row):?> <div class="img_view"><img class='iYuUpload-View' src='/Upl

  • php处理多图上传压缩代码功能

    网上看了一些资料,关于处理图片压缩的,找到的大部分是单图压缩的,要么是单前端或者后端的,所以就自己整了下前后端压缩,并支持多图的压缩图片实例.代码有点多,直接复制到编辑器看会比较清楚 1.先创建的一个简单的上传页面upload.php.先通过前端代码压缩图片,直接上代码 <!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <meta name="viewport&quo

  • Spring学习笔记2之表单数据验证、文件上传实例代码

    在上篇文章给大家介绍了Spring学习笔记1之IOC详解尽量使用注解以及java代码,接下来本文重点给大家介绍Spring学习笔记2之表单数据验证.文件上传实例代码,具体内容,请参考本文吧! 一.表单数据验证 用户注册时,需要填写账号.密码.邮箱以及手机号,均为必填项,并且需要符合一定的格式.比如账号需要32位以内,邮箱必须符合邮箱格式,手机号必须为11位号码等.可以采用在注册时验证信息,或者专门写一个工具类用来验证:来看下在SpringMVC中如何通过简单的注释实现表单数据验证. 在javax

  • Thinkphp整合阿里云OSS图片上传实例代码

    Thinkphp3.2整合阿里云OSS图片上传实例,图片上传至OSS可减少服务器压力,节省宽带,安全又稳定,阿里云OSS对于做负载均衡非常方便,不用传到各个服务器了 首先引入阿里云OSS类库 <?php namespace Home\Controller; use Think\Controller; use OSS\Core\OssException; vendor('aliyun.autoload'); 上传图片自己写,上传成功到阿里云后,删除临时文件 function aliyun() {

  • php layui实现前端多图上传实例

    php结合layui前端实现多图上传 前端html代码 <div class="layui-upload"> <button type="button" class="layui-btn layui-btn-normal" id="testList">请选择图片</button> <span class="num_pic"></span> <

  • iOS实现视频压缩上传实例代码

    之前写过图片上传PHP服务器,今天把接口稍微改了一下,把视频上传的代码贴出来,目前上传功能已经调通,视频的压缩代码上似乎并不完善,后续会完善压缩部分的代码: - (void)convertVideoWithURL:(NSURL *)url { NSDate *date = [NSDate date]; NSDateFormatter *dateformatter = [[NSDateFormatter alloc]init]; [dateformatter setDateFormat:@"YYY

  • RxJava+Retrofit+OkHttp实现文件上传

    背景 在实际运用中上传是一个必不可少的功能,所以我们在封装二的基础上加入上传的功能,同时需要附带上传进度! 效果 实现 1.定义service接口 注意:Multipart是指定大文件上传过程中的标示,一般上传图片的过程中我们需要附带信息,所以我们需要用到@part指定传递的数值,MultipartBody.Part是指定传递的文件: /*上传文件*/ @Multipart @POST("AppYuFaKu/uploadHeadImg") Observable<BaseResul

  • PHP仿微信多图片预览上传实例代码

    生产图片区域,上传按钮#btn可替换自己想要的图片 <ul id="ul_pics" class="ul_pics clearfix"> <li><img src="logo.png" id="btn" class="img_common" /></li> </ul> plupload上传 var uploader = new plupload.U

  • ajax异步实现文件分片上传实例代码

    前言 使用Ajax上传文件的应用场景颇多,比如上传用户头像.博客文章中插入图片.对认证用户相关身份进行校验等等很多很多.这篇文章主要介绍了关于ajax异步实现文件分片上传的相关内容,下面话不多说了,来一起看看详细的介绍吧 实例代码: <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>JS分片上传-极速上传</ti

随机推荐