提问者:小点点

将文件上传到Firebase存储时收到“任务尚未完成”错误


所以我做了一个应用程序,用户可以以图像和描述的形式提供数据,然后这些数据将被上传到Fi恢复,图像将被保存到Firebase Storage。运行后,图像成功保存到Firebase Storage,但Fi恢复中的数据没有变化。我使用这段代码:

val filePathAndName="product_images/"+""+timeStamp

val storageReference=FirebaseStorage.getInstance().getReference(filePathAndName)

val uploadTask= storageReference.putFile(image_Uri)
    uploadTask.addOnSuccessListener {  taskSnapShot->
        val uriTask=taskSnapShot.storage.downloadUrl

        val downloadImageUri=uriTask.result

        val item = Item(
            ""+firebaseAuth.uid,
            timeStamp,
            kategori,
            berat_sampah.toDouble(),
            deskripsi,
            ""+downloadImageUri,
        )
        FirestoreClass().addItem(this@AddProductActivity, FirestoreClass().getCurrentUserID(),item)

在我的FirestoreClass中:

class FirestoreClass {

    private  val mFireStore=FirebaseFirestore.getInstance()
    fun addItem(activity: AddProductActivity, userId: String, itemInfo: Item){
        mFireStore.collection(Constants.USERS).document(userId)
            .collection(Constants.PRODUCT).document(itemInfo.productId)
            .set(itemInfo, SetOptions.merge())
    }

    fun getCurrentUserID(): String{
        val currentUser= FirebaseAuth.getInstance().currentUser
        var currentUserID=""
        if(currentUser!=null)
        {
            currentUserID=currentUser.uid
        }
        return currentUserID
    }

    }

似乎在存储中上传图片后,活动被强制关闭。并显示此错误:

E/AndroidRuntime: FATAL EXCEPTION: main
    Process: com.example.b1, PID: 15693
    java.lang.IllegalStateException: Task is not yet complete
        at com.google.android.gms.common.internal.Preconditions.checkState(com.google.android.gms:play-services-basement@@17.1.0:29)
        at com.google.android.gms.tasks.zzu.zzb(Unknown Source:121)
        at com.google.android.gms.tasks.zzu.getResult(Unknown Source:12)
        at com.example.b1.activity.AddProductActivity$addProduct$1.onSuccess(AddProductActivity.kt:163)
        at com.example.b1.activity.AddProductActivity$addProduct$1.onSuccess(AddProductActivity.kt:35)
        at com.google.firebase.storage.StorageTask.lambda$new$0$StorageTask(StorageTask.java:123)
        at com.google.firebase.storage.-$$Lambda$StorageTask$xlHsb5OfSRp-di5vg8sdDdXsCO4.raise(Unknown Source:6)
        at com.google.firebase.storage.TaskListenerImpl.lambda$onInternalStateChanged$2$TaskListenerImpl(TaskListenerImpl.java:90)
        at com.google.firebase.storage.-$$Lambda$TaskListenerImpl$S8elBxPWPDCBbbHv0Z6yA1jvX68.run(Unknown Source:6)
        at android.os.Handler.handleCallback(Handler.java:873)
        at android.os.Handler.dispatchMessage(Handler.java:99)
        at android.os.Looper.loop(Looper.java:193)
        at android.app.ActivityThread.main(ActivityThread.java:6669)
        at java.lang.reflect.Method.invoke(Native Method)
        at com.android.internal.os.RuntimeInit$MethodAndArgsCaller.run(RuntimeInit.java:493)
        at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:858)

为什么会发生这种情况?以及Error中提到的尚未完成的任务是什么


共1个答案

匿名用户

我认为问题可能来自这里:

val uriTask=taskSnapShot.storage.downloadUrl

val downloadImageUri=uriTask.result

downloadUrl属性实际上是一个异步方法调用。所以你不能只从任务中获取结果,而是必须等待它——类似于你已经为putFile()所做的。

像这样的东西:

taskSnapShot.storage.downloadUrl.addOnSuccessListener { task ->
    val downloadUri = task.result
    // Use the downloadUri here
}

另请参阅Firebase留档中有关获取上传文件的下载URL的示例。