在看了网上多篇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做多图上传的小笔记,希望对大家的学习有所帮助,也希望大家多多支持小牛知识库。
本文向大家介绍Retrofit+Rxjava实现文件上传和下载功能,包括了Retrofit+Rxjava实现文件上传和下载功能的使用技巧和注意事项,需要的朋友参考一下 Retrofit简介: 在Android API4.4之后,Google官方使用了square公司推出的okHttp替换了HttpClient的请求方式。后来square公司又推出了基于okHttp的网络请求框架:Retrofit。
本文向大家介绍Retrofit Rxjava实现图片下载、保存并展示实例,包括了Retrofit Rxjava实现图片下载、保存并展示实例的使用技巧和注意事项,需要的朋友参考一下 首先我们看一下Retrofit常规的用法,在不使用Rxjava的情况下,我们默认返回的是Call。 但是如果我们要配合Rxjava使用,那么就要按照如下方式来重新定义我们的方法: 返回一个Observable,方法名很直
本文向大家介绍php layui实现前端多图上传实例,包括了php layui实现前端多图上传实例的使用技巧和注意事项,需要的朋友参考一下 php结合layui前端实现多图上传 前端html代码 js 代码 后端代码 上传效果: 以上就是php结合layui前端实现多图上传的全部知识点,感谢大家对呐喊教程的支持。
本文向大家介绍基于Ok+Rxjava+retrofit实现断点续传下载,包括了基于Ok+Rxjava+retrofit实现断点续传下载的使用技巧和注意事项,需要的朋友参考一下 本文为大家分享了实现断点续传下载的具体代码,供大家参考,具体内容如下 1、基于Ok+Rxjava实现断点续传下载 2、基于Ok+Rxjava+Retrofit实现断点续传下载 上一篇博客中介绍了基于Ok+Rxjava实现断点
本文向大家介绍rails上传图片代码实例,包括了rails上传图片代码实例的使用技巧和注意事项,需要的朋友参考一下 今天讲解一下rails的图片上传,就是最平常的上传图片 这里的rails版本2.3.5 首先新建一个write_pic model内容如下: 上传 图片是用的插件所以最上面加载了插件。 调用write_pic 这个model的model文件写法如下 controller里面不用在
本文向大家介绍Bootstrap+PHP实现多图上传功能实例详解,包括了Bootstrap+PHP实现多图上传功能实例详解的使用技巧和注意事项,需要的朋友参考一下 使用bootstrap界面美观,可预览,可拖拽上传,可配合ajax异步或同步上传,下面是效果图: 前端代码:fileinput.html 后台代码: 总结 以上所述是小编给大家介绍的Bootstrap+PHP实现多图上传功能实例详解,希