打造高效上传体验:基于Kotlin的Android快速上传框架

发布于:2024-06-01 ⋅ 阅读:(91) ⋅ 点赞:(0)

1. 引言

在Android开发中,文件上传操作常常面临各种挑战,为此我开源了一个高效、易用的快速上传框架,助力开发者轻松实现文件上传功能。 GitHub项目地址: 点我

2. 框架特点概述

  • 纯Kotlin编写:简洁、现代的编程语言。
  • MVVM架构:利用ViewModel、LiveData和Lifecycle组件。
  • 高效的协程:异步处理上传任务,保证界面流畅。
  • OkHttp封装:稳定可靠的HTTP请求处理。

3. 效果预览

单文件上传模式 单文件上传模式多个文件上传 多个文件同时上传模式
单文件上传模式 单文件上传模式多个文件上传 多个文件同时上传模式

4. 快速开始

依赖配置

  • 添加仓库
// build.gradle(Project:)
allprojects {
    repositories {
        maven { url 'https://jitpack.io' }
    }
}
  • 添加依赖
// build.gradle(Module:)
dependencies {
    implementation 'com.github.XJ-Up:quickupload:1.0.0'
}

5.详细使用说明

第一步 Application进行初始化配置

//defaultNotificationChannel用于后台服务需自行createNotificationChannel详情见demo(startForegroundService)
//debug 用于是否打印日志
 UploadConfiguration.initialize(
            context = this,
            defaultNotificationChannel = notificationChannelID,
            debug = BuildConfig.DEBUG
        )

第二步 创建并启动上传任务(可分开)

单文件
//单文件
     QuickUploadRequest(this, serverUrl = "你的上传地址")
                    .setMethod("POST")
                    .addFileToUpload(
                        filePath = mPath, //文件地址(注意:content://也行哦)
                        parameterName = "files" //后台服务接收的参数名
                    )
                    .setResumedFileStart(0)//如果需要断点续传调用此方法,默认情况下不需要调用
                    .setUploadID("1")
                    .startUpload()
多文件同时上传
//同时多文件(不支持断点续传)
 QuickUploadRequest(this, serverUrl = "你的上传地址")
                    .setMethod("POST")
                    .apply {
                        filePath.forEachIndexed { index, s ->
                            addFileToUpload(
                                filePath = s,
                                parameterName = "files"
                            )
                        }
                    }
                    .setUploadID("2")
                    .startUpload()
断点续传
   //如果需要断点续传调用此方法,默认情况下不需要调用(注意:0或不传效果都是重新上传,此方法必须在startUpload之前调用)
   //参数传入上次断点位置(一般这个位置通过后台服务器获取)
   quickUploadRequest.setResumedFileStart(0)
                  

第三步 监听上传获取上传详情

   RequestLiveData(this,object :RequestObserverDelegate{
            override fun onCompleted(context: Context, uploadInfo: UploadInfo) {
                //上传完成时调用 ,注意:成功或错误都会触发
            }

            override fun onCompletedWhileNotObserving() {
                //仅在监听单个上传ID并注册请求观察者时调用
            }

            override fun onError(context: Context, uploadInfo: UploadInfo, exception: Throwable) {
                //出现异常时
            }

            override fun onProgress(context: Context, uploadInfo: UploadInfo) {
                //上传中进度
            }

            override fun onSuccess(
                context: Context,
                uploadInfo: UploadInfo,
                serverResponse: ServerResponse
            ) {
                //上传成功时
            }

            override fun onWait(context: Context, uploadInfo: UploadInfo) {
                //加入上传队列,但不一定开始上传时
            }
        })

自定义日志

     	    Logger.setDelegate(object : Logger.Ext{
           override fun debug(component: String, uploadId: String, message: String) {
              
           }

           override fun error(
               component: String,
               uploadId: String,
               message: String,
               exception: Throwable?
           ) {
              
           }

           override fun info(component: String, uploadId: String, message: String) {
              
           }

       })

配置或管理 API

        quickUploadRequest.addArrayParameter()//将具有多个值的参数添加到此上传请求中
        quickUploadRequest.addHeader()//向此上传请求添加标头
        quickUploadRequest.addParameter()//为该上传请求添加一个参数
        quickUploadRequest.setMethod()//设置要使用的HTTP方法
        quickUploadRequest.setMaxRetries()//设置发生错误时库将尝试的最大重试次数
        quickUploadRequest.setAutoDeleteFilesAfterSuccessfulUpload()//设置上传成功后自动删除文件
        quickUploadRequest.setUploadID()//设置上传id



        UploadConfiguration.dispatcher= //设置自定义调度器
        UploadConfiguration.maxConcurrentTasks=//设置最大并发任务数
        UploadConfiguration.retryPolicy=//设置上传服务重试策略 
        UploadConfiguration.defaultNotificationChannel=//设置通知通道
        

具体使用可参考demo

GitHub项目地址: 点我

6.常见问题解答

  • 如何处理上传失败?
    **当上传失败时 RequestLiveData中的 onError 会触发,通过exception参数获取异常信息 ,常见的异常:
    UserCancelledUploadException 用户已取消上传的异常
    UploadError 上传过程错误的异常
    NoNetworkException 网络连接断开的异常。它们都继承Throwable。通过判断异常决定后续处理 **
  • 如何取消上传任务?
UploadService.taskList//获取当前所有活跃的上传任务
UploadService.stopAllUploads()//停止所有活动的上传任务。onError触发。
UploadService.stopUpload(uploadId)//停止特定上传任务
UploadService.stop(context)//如果当前没有正在运行的任务,则停止 UploadService
UploadService.stop(context, forceStop = true) //强制停止 UploadService 中止任何当前正在运行的任务
  • 如何获取上传进度?
    **当上传失败时 RequestLiveData中的 onProgress 会触发,通过 uploadInfo.progressPercent获取 **

7.结语

**希望这个框架能帮助你简化上传任务,提高开发效率。如果你有任何问题或建议,欢迎在GitHub点我上提出Issue或提交Pull Request。让我们一起打造更好的开源项目! **


网站公告

今日签到

点亮在社区的每一天
去签到