Android中Okhttp3实现上传多张图片同时传递参数

前端之家收集整理的这篇文章主要介绍了Android中Okhttp3实现上传多张图片同时传递参数前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。

之前上传图片都是直接将图片转化为io流传给服务器,没有用框架传图片

最近做项目,打算换个方法上传图片

Android发展到现在,Okhttp显得越来越重要,所以,这次我选择用Okhttp上传图片

Okhttp目前已经更新到Okhttp3版本了,用法跟之前相比,也有一些差别。在网上找了很多资料,

并和java后台同事反复调试,终于成功上传多张图片,同时传递一些键值对参数。

以下是我对该过程的封装:

/**

  • 上传多张图片及参数

  • @param reqUrl URL地址

  • @param params 参数

  • @param pic_key 上传图片的关键字

  • @param paths 图片路径
    */
    public Observable sendMultipart(String reqUrl,Map<String,String> params,String pic_key,List files){
    return Observable.create(new Observable.OnSubscribe(){

    @Override
    public void call(Subscriber<? super String> subscriber) {
    MultipartBody.Builder multipartBodyBuilder = new MultipartBody.Builder();
    multipartBodyBuilder.setType(MultipartBody.FORM);
    //遍历map中所有参数到builder
    if (params != null){
    for (String key : params.keySet()) {
    multipartBodyBuilder.addFormDataPart(key,params.get(key));
    }
    }
    //遍历paths中所有图片绝对路径到builder,并约定key如“upload”作为后台接受多张图片的key
    if (files != null){
    for (File file : files) {
    multipartBodyBuilder.addFormDataPart(pic_key,file.getName(),RequestBody.create(MEDIA_TYPE_PNG,file));
    }
    }
    //构建请求体
    RequestBody requestBody = multipartBodyBuilder.build();

    Request.Builder RequestBuilder = new Request.Builder();
    RequestBuilder.url(reqUrl);// 添加URL地址
    RequestBuilder.post(requestBody);
    Request request = RequestBuilder.build();
    mOkHttpClient.newCall(request).enqueue(new Callback() {
    @Override
    public void onFailure(Call call,IOException e) {
    subscriber.onError(e);
    subscriber.onCompleted();
    call.cancel();
    }

     @Override
     public void onResponse(Call call,Response response) throws IOException {
       String str = response.body().string();
       subscriber.onNext(str);
       subscriber.onCompleted();
       call.cancel();
     }

    });
    }
    });
    }

在UI界面的调用

() { @Override public void onCompleted() {
      }

      @Override
      public void onError(Throwable throwable) {
        LogUtil.i(TAG,"throwable:" + throwable.toString());
      }

      @Override
      public void onNext(String s) {

        LogUtil.i(TAG,"s:" + s);
      }
    }); 

调试过程中,有一次将multipartBodyBuilder.addFormDataPart(pic_key,file));写成了 multipartBodyBuilder.addFormDataPart(pic_key,null,file));导致后台无法用常规方法获取图片(虽然断点调试时也能看到图片数据),这点需要注意。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持编程之家。

原文链接:https://www.f2er.com/js/41529.html

猜你在找的JavaScript相关文章