使用Coroutine+Retrofit将文件/图像上传到服务器

编程入门 行业动态 更新时间:2024-10-28 05:13:30
本文介绍了使用Coroutine+Retrofit将文件/图像上传到服务器的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!

问题描述

我是新的协程程序,我尝试将文件上传到服务器(使用Retroff2.9.0),但没有收到响应。 下面是代码行

private suspend fun uploadFile(inputFiles: List<String>,channel:Channel<Any>): List<FileResponse>? {
        val partList = buildFilePart(inputFiles)
        QLog.d(TAG,"uploadFile going 1")
        val response = RequestHelper.getUpLoadFilesKotlinRequest().uploadFiles(partList)
        QLog.d(TAG,"uploadFile going 2")
        return response.body()
}
interface UploadFileApiKotlin {
    @Multipart
    @POST("/uploadFile")
    suspend fun uploadFiles(
        @Part listUri: List<MultipartBody.Part>
    ): Response<List<FileResponse>?>
}

检查logcat后,我只看到一行代码:

正在上传文件%1

没有日志行:UploadFile Going%2

协同例程似乎在以下行挂起:val response = RequestHelper.getUpLoadFilesKotlinRequest().uploadFiles(partList)

您能帮我解决这个问题吗? 提前感谢

推荐答案

我发布了another question,最终我自己得到了答案

suspend fun uploadFile() = suspendCoroutine<Response<List<FileResponse>?>> { continuation ->
    val call = RequestHelper.getUpLoadFilesKotlinRequest().uploadFiles(partList)
    call.enqueue(object : Callback<Response<List<FileResponse>?>> {
        override fun onResponse(
            call: Call<Response<List<FileResponse>?>>,
            response: Response<Response<List<FileResponse>?>>
        ) {
            // Resume coroutine with a value provided by the callback
            continuation.resumeWith(response.data)
        }

        override fun onFailure(
            call: Call<Response<List<FileResponse>?>>,
            t: Throwable
        ) {
            continuation.resumeWithException(t)
        }
    })
}

这篇关于使用Coroutine+Retrofit将文件/图像上传到服务器的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!

更多推荐

[db:关键词]

本文发布于:2023-03-13 17:47:57,感谢您对本站的认可!
本文链接:https://www.elefans.com/category/jswz/34/620880.html
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系,我们将在24小时内删除。
本文标签:图像   服务器   文件   Coroutine   Retrofit

发布评论

评论列表 (有 0 条评论)
草根站长

>www.elefans.com

编程频道|电子爱好者 - 技术资讯及电子产品介绍!