Flutter:获取 Firebase 存储下载 URL 和上传状态 [重复]
Posted
技术标签:
【中文标题】Flutter:获取 Firebase 存储下载 URL 和上传状态 [重复]【英文标题】:Flutter: Get FirebaseStorage Download URL & Upload Status [duplicate] 【发布时间】:2019-03-13 10:33:39 【问题描述】:我是新来的颤振。我正在尝试获取StorageUploadTask
状态并在状态为isCompleted
和isSuccessful
时进行下载。我在网上找到的例子是旧版本的:
StorageUploadTask uploadTask = ref.putFile(avatarImageFile);
Uri downloadUrl = (await uploadTask.future).downloadUrl;
以上不适用于新的firebase_storage
plugin 版本。请帮忙。以下是我目前的代码。
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才能在屏幕上获得上传状态。 【参考方案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();以上是关于Flutter:获取 Firebase 存储下载 URL 和上传状态 [重复]的主要内容,如果未能解决你的问题,请参考以下文章
如何以单独的方法获取 Flutter Firebase 存储?