Mit Cloud Storage for Firebase können Sie den Inhalt Ihres Cloud Storage-Buckets auflisten. Die SDKs geben sowohl die Elemente als auch die Präfixe von Objekten unter der aktuellen Cloud Storage-Referenz zurück.
Für Projekte, in denen die List API verwendet wird, sind Cloud Storage for Firebase-Regeln der Version 2 erforderlich. Wenn Sie bereits ein Firebase-Projekt haben, folgen Sie der Anleitung im Leitfaden zu Sicherheitsregeln.
list() verwendet die Google Cloud Storage List API.
In Cloud Storage for Firebase verwenden wir / als Trennzeichen, um die Semantik des Dateisystems zu emulieren. Damit große, hierarchische Cloud Storage-Buckets effizient durchlaufen werden können, gibt die List API Präfixe und Elemente separat zurück. Wenn Sie beispielsweise eine Datei /images/uid/file1 hochladen,
root.child('images').listAll()gibt/images/uidals Präfix zurück.root.child('images/uid').listAll()gibt die Datei als Element zurück.
Das Cloud Storage for Firebase-SDK gibt keine Objektpfade zurück, die zwei aufeinanderfolgende / enthalten oder mit einem / enden. Angenommen, Sie haben einen Bucket mit den folgenden Objekten:
correctPrefix/happyItemwrongPrefix//sadItemlonelyItem/
Die Listenoperationen für Elemente in diesem Bucket ergeben die folgenden Ergebnisse:
- Der Listenoperation am Stamm gibt die Verweise auf
correctPrefix,wrongPrefixundlonelyItemalsprefixeszurück. - Der Listenvorgang unter
correctPrefix/gibt die Verweise aufcorrectPrefix/happyItemalsitemszurück. - Der Listenvorgang unter
wrongPrefix/gibt keine Verweise zurück, dawrongPrefix//sadItemzwei aufeinanderfolgende/-Elemente enthält. - Der Listenoperation bei
lonelyItem/werden keine Verweise zurückgegeben, da das ObjektlonelyItem/mit/endet.
Alle Dateien auflisten
Mit listAll können Sie alle Ergebnisse für ein Verzeichnis abrufen.
Diese Methode eignet sich am besten für kleine Verzeichnisse, da alle Ergebnisse im Arbeitsspeicher gepuffert werden.
Der Vorgang gibt möglicherweise auch keinen konsistenten Snapshot zurück, wenn während des Vorgangs Objekte hinzugefügt oder entfernt werden.
Verwenden Sie für eine lange Liste die paginierte Methode list(), da bei listAll() alle Ergebnisse im Arbeitsspeicher gepuffert werden.
Das folgende Beispiel veranschaulicht listAll.
final storageRef = FirebaseStorage.instance.ref().child("files/uid");
final listResult = await storageRef.listAll();
for (var prefix in listResult.prefixes) {
// The prefixes under storageRef.
// You can call listAll() recursively on them.
}
for (var item in listResult.items) {
// The items under storageRef.
}
Listenergebnisse paginieren
Die list() API begrenzt die Anzahl der zurückgegebenen Ergebnisse. list() bietet einen konsistenten Seitenaufruf und macht ein „pageToken“ verfügbar, mit dem gesteuert werden kann, wann zusätzliche Ergebnisse abgerufen werden sollen.
Das pageToken codiert den Pfad und die Version des letzten Elements, das im vorherigen Ergebnis zurückgegeben wurde. In einer nachfolgenden Anfrage mit dem pageToken werden Elemente angezeigt, die nach dem pageToken stehen.
Im folgenden Beispiel wird gezeigt, wie ein Ergebnis paginiert wird:
Stream<ListResult> listAllPaginated(Reference storageRef) async* {
String? pageToken;
do {
final listResult = await storageRef.list(ListOptions(
maxResults: 100,
pageToken: pageToken,
));
yield listResult;
pageToken = listResult.nextPageToken;
} while (pageToken != null);
}
Fehler verarbeiten
list() und listAll() schlagen fehl, wenn Sie die Sicherheitsregeln nicht auf Version 2 aktualisiert haben. Aktualisieren Sie Ihre Sicherheitsregeln, wenn dieser Fehler angezeigt wird:
Listing objects in a bucket is disallowed for rules_version = "1".
Please update storage security rules to rules_version = "2" to use list.
Andere mögliche Fehler können darauf hinweisen, dass der Nutzer nicht die richtige Berechtigung hat. Weitere Informationen zu Fehlern finden Sie auf der Seite Fehlerbehebung.