Android 使用Retrofit 以纯二进制文件流上传文件

一、背景

一般上传文件都是以表单形式上传文件,最近项目中涉及到非表单形式上传文件流,分为单个文件流上传、大文件分段上传,此种情景资料较少,这里记录下。

二、方案介绍

2.1 需求协议
复制代码
1. 上传文件
API 端点:/service/upload
● 方法:PUT
● 请求参数:
    ○ filename:文件名(必选)
○ 请求头:
    ○ Authorization:用于身份验证的 token(必选)
    ○ X-Request-ID:请求的唯一标识符(必选)
    ○ Upload-Offset:当前上传块的偏移量(必选)
        ■ 单位:byte
    ○ Upload-Type:文件上传方式(必选)
        ■ 1 上传到相册(/storage/emulated/0/Pictures/)
        ■ 2 上传到sdcard(/sdcard/)
○ 请求体
    ○ 文件二进制数据
2.2 定义接口
复制代码
格式:http://example.com/api/upload?filename=example.txt

所以应该这样定义接口:

   @PUT("/service/upload")
RequestBody): Call<ResponseBody>
   fun uploadFile(@Query("filename") filename:String,  @Body body: RequestBody):Call<ResponseBody>
2.3 定义一个RequestInterceptor 迭代器,将请求参数放到请求头中
复制代码
class RequestInterceptor(val authorization:String,val requestId:String,val offset:String,val uploadType:String) : Interceptor {

    override fun intercept(chain: Interceptor.Chain): Response {
        val request = chain.request()
        val requestBuilder = request.newBuilder()
   
        requestBuilder.addHeader("Authorization", authorization)
        requestBuilder.addHeader("X-Request-ID", requestId)

        if(offset.isNotEmpty()){
            requestBuilder.addHeader("Upload-Offset", offset)
        }

        if(uploadType.isNotEmpty()){
            requestBuilder.addHeader("Upload-Type", uploadType)
        }

//        requestBuilder.removeHeader("Content-Length")
//        requestBuilder.removeHeader("Content-Transfer-Encoding")
//        requestBuilder.removeHeader("Content-Disposition")

        return chain.proceed(requestBuilder.build())
    }
}
2.4调用接口
复制代码
      // 创建文件名请求体
            val requestBody = RequestBody.create(null, file)//第一个参数传null

            val call = RetrofitClient.getUploadFileService(token, requestId, "0", uploadType)
                .uploadFile(file.name, requestBody)

用到的相关库:

复制代码
   implementation 'com.squareup.retrofit2:retrofit:2.9.0'
   implementation 'com.squareup.retrofit2:converter-gson:2.9.0'
   implementation 'com.squareup.okhttp3:logging-interceptor:3.14.9'
相关推荐
感谢地心引力4 小时前
安卓、苹果手机无线投屏到Windows
android·windows·ios·智能手机·安卓·苹果·投屏
优雅的潮叭8 小时前
cud编程之 reduce
android·redis·缓存
2601_949613028 小时前
flutter_for_openharmony家庭药箱管理app实战+用药知识详情实现
android·javascript·flutter
一起养小猫8 小时前
Flutter for OpenHarmony 实战 表单处理与验证完整指南
android·开发语言·前端·javascript·flutter·harmonyos
2601_949975089 小时前
flutter_for_openharmony城市井盖地图app实战+附近井盖实现
android·flutter
倾云鹤9 小时前
通用Digest认证
android·digest
我是阿亮啊9 小时前
Android 自定义 View 完全指南
android·自定义·自定义view·viewgroup
2601_9498333911 小时前
flutter_for_openharmony口腔护理app实战+意见反馈实现
android·javascript·flutter
峥嵘life11 小时前
Android 16 EDLA测试STS模块
android·大数据·linux·学习
TheNextByte111 小时前
如何打印Android手机联系人?
android·智能手机