Android Retrofit 实现图文上传-文字参数类型

回顾

Android Retrofit 实现文字(参数)和多张图片一起上传 博客中,我们详细介绍了多张图片和文字参数上传的具体原理和实现,今天我们重点说说文字参数类型的问题。

Post请求抓包信息:

这里写图片描述

接口定义:

这里写图片描述

从抓包信息中看到文字类型的参数字段名是“data”,值是“jdsjlzx”。

其中的Content-Type信息如下:

Content-Type: application/json; charset=UTF-8

无论何种请求,Content-Type类型不能错。请求失败,排查错误首先从这个Content-Type开始,其次是Content-Disposition。

下面我们从一个真实案例来说一说这个Content-Type。

案例讲解

接口

这里写图片描述

从上面图片中就看到上传头像需要传递userId、token等参数。

后台接口开发人员测试接口一般在web上面调试好,移动端开发人员就可以根据接口进行联调了。

web端上传头像时请求抓包信息如下所示:

这里写图片描述

上图红色箭头所指之处就是我们需要注意的地方。

Content-Type类型不是“application/json”,而是“text/plain”。

Content-Type: text/plain; charset=UTF-8

注意:

“@Part(“data”) String des”在Post请求中默认的Content-Type类型就是“application/json”

接口定义如果按照前面文章介绍的那样写,如下图所示,肯定是不行的。

这里写图片描述

经过网上查资料,我们找到了解决办法,参考:http://stackoverflow.com/questions/37072368/retrofit-body-with-multipart-having-issue

解决问题

“@Part(“data”) String des”在Post请求中默认的Content-Type类型是“application/json”,这就说明我们在接口中不能再使用@Part注解了,我们需要在代码中指定类型。

上传接口定义

这里写图片描述

上传头像

主要代码如下图所示:

这里写图片描述

这里有个toRequestBody函数,主要功能是将文字参数类型转换为“text/plain”。

toRequestBody函数如下图所示:

这里写图片描述

上传头像请求结果抓包信息:

这里写图片描述

“userId”、“token”等文字参数的类型成功转换为了“text/plain”类型。

大功告成,看看服务器返回结果吧。

这里写图片描述

That’s all, thank you.

  • 12
    点赞
  • 27
    收藏
    觉得还不错? 一键收藏
  • 13
    评论
Android 中使用 Retrofit 上传图片可以通过 `@Multipart` 和 `@Part` 注解实现。以下是 Retrofit 2.0 实现图文上传的方法总结: 1. 添加依赖库 在项目的 `build.gradle` 文件中添加以下依赖库: ```groovy implementation 'com.squareup.retrofit2:retrofit:2.9.0' implementation 'com.squareup.retrofit2:converter-gson:2.9.0' implementation 'com.squareup.retrofit2:converter-scalars:2.9.0' ``` 2. 创建 Retrofit 实例 ```java Retrofit retrofit = new Retrofit.Builder() .baseUrl(BASE_URL) .addConverterFactory(GsonConverterFactory.create()) .build(); ``` 3. 创建 API 接口 ```java public interface ApiService { @Multipart @POST("upload") Call<ResponseBody> upload( @Part("description") RequestBody description, @Part MultipartBody.Part file); } ``` 其中,`@Multipart` 注解表示这是一个包含文本和文件的表单;`@POST("upload")` 表示上传的 URL 地址;`@Part("description") RequestBody description` 表示上传的文本参数,`description` 是参数名,可以自己定义;`@Part MultipartBody.Part file` 表示上传的文件参数。 4. 创建请求参数 ```java File file = new File(filePath); RequestBody requestFile = RequestBody.create(MediaType.parse("image/*"), file); MultipartBody.Part body = MultipartBody.Part.createFormData("file", file.getName(), requestFile); RequestBody description = RequestBody.create(MediaType.parse("multipart/form-data"), "description"); ``` 5. 发送网络请求 ```java ApiService apiService = retrofit.create(ApiService.class); Call<ResponseBody> call = apiService.upload(description, body); call.enqueue(new Callback<ResponseBody>() { @Override public void onResponse(Call<ResponseBody> call, Response<ResponseBody> response) { // 成功上传后的处理 } @Override public void onFailure(Call<ResponseBody> call, Throwable t) { // 上传失败后的处理 } }); ``` 以上就是 Retrofit 2.0 实现图文上传的方法总结。注意,在 `AndroidManifest.xml` 文件中需要添加网络权限: ```xml <uses-permission android:name="android.permission.INTERNET" /> ```

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 13
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值