【问题标题】:Flutter: Get FirebaseStorage Download URL & Upload Status [duplicate]Flutter:获取 Firebase 存储下载 URL 和上传状态 [重复]
【发布时间】:2019-03-13 10:33:39
【问题描述】:

我是新来的颤振。我正在尝试获取StorageUploadTask 状态并在状态为isCompletedisSuccessful 时进行下载。我在网上找到的例子是旧版本的:

StorageUploadTask uploadTask = ref.putFile(avatarImageFile);
Uri downloadUrl = (await uploadTask.future).downloadUrl;

以上不适用于新的firebase_storageplugin 版本。请帮忙。以下是我目前的代码。

StorageUploadTask uploadTask = ref.putFile(avatarImageFile);

    StorageReference downRef = uploadTask.lastSnapshot.ref;
    String downloadUrl = await downRef.getDownloadURL();

    if(uploadTask.isComplete) {
      if(uploadTask.isSuccessful) {
        print('Upload Successful');
      } else if(uploadTask.isCanceled) {
        print('Upload Cancelled');
      } else {
        print('${uploadTask.lastSnapshot.error}');
      }
    } else if(uploadTask.isInProgress){
        print('Upload in Progress');
      } else if(uploadTask.isPaused) {
        print('Upload Paused');
      }

【问题讨论】:

  • 您需要订阅uploadTask.event Stream才能在屏幕上获得上传状态。

标签: firebase dart flutter firebase-storage


【解决方案1】:

较新版本:

由于.onComplete已被删除,现在您只需要等待任务完成即可:

final ref = FirebaseStorage.instance.ref('images/foo.png');
await ref.putFile(fileToUpload);
String url = await ref.getDownloadURL(); // <-- This is your download url.

旧版本:

旧版本的插件不再允许您使用task.future(),并且在他们说使用lastSnapshot 的文档中这对我不起作用。所以,我使用了onComplete。这是可行的解决方案:

var ref = FirebaseStorage.instance.ref().child("your_path");
var uploadTask = ref.putFile(avatarImageFile);
var storageTaskSnapshot = await uploadTask.onComplete;
var downloadUrl = await storageTaskSnapshot.ref.getDownloadURL();

【讨论】:

  • 这似乎现在不起作用,请提供更新的答案。没有什么像 onComplete
  • 在新版本中,一个简单的等待应该可以解决问题:最终参考参考 = FirebaseStorage.instance .ref().child("your_path");等待参考.putFile(fileToUpload);返回等待参考.getDownloadURL();
猜你喜欢
  • 2018-07-04
  • 1970-01-01
  • 2018-01-24
  • 2018-12-30
  • 2017-07-08
  • 2018-12-28
  • 2020-10-31
  • 2020-12-05
  • 2021-12-27
相关资源
最近更新 更多