Cloud Storage for Firebase ermöglicht Ihnen das Auflisten der Inhalte Ihres Cloud Storage Buckets. Die SDKs geben sowohl die Elemente als auch die Präfixe von Objekten unter der aktuellen Cloud Storage Referenz zurück.
Für Projekte, die die List API verwenden, ist die Cloud Storage for Firebase Regelversion 2 erforderlich. Wenn Sie bereits ein Firebase-Projekt haben, folgen Sie der Anleitung in dem Leitfaden zu Sicherheitsregeln.
list() verwendet die
Google Cloud Storage List API.
In Cloud Storage for Firebase, verwenden wir / als Trennzeichen, wodurch wir die Semantik des Dateisystems emulieren können. Um ein effizientes Durchlaufen großer,
hierarchischer Cloud Storage Buckets zu ermöglichen, 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. Betrachten Sie beispielsweise einen Bucket mit den folgenden Objekten:
correctPrefix/happyItemwrongPrefix//sadItemlonelyItem/
Die Listenoperationen für Elemente in diesem Bucket führen zu den folgenden Ergebnissen:
- Die Listenoperation im Stammverzeichnis gibt die Referenzen auf
correctPrefix,wrongPrefixundlonelyItemalsprefixeszurück. - Die Listenoperation unter
correctPrefix/gibt die Referenzen aufcorrectPrefix/happyItemalsitemszurück. - Die Listenoperation unter
wrongPrefix/gibt keine Referenzen zurück dawrongPrefix//sadItemzwei aufeinanderfolgende/enthält. - Die Listenoperation unter
lonelyItem/gibt keine Referenzen zurück 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.
Die Operation 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 listAll() alle Ergebnisse im Arbeitsspeicher puffert.
Das folgende Beispiel zeigt listAll:
Kotlin
val storage = Firebase.storage val listRef = storage.reference.child("files/uid") // You'll need to import com.google.firebase.storage.component1 and // com.google.firebase.storage.component2 listRef.listAll() .addOnSuccessListener { (items, prefixes) -> for (prefix in prefixes) { // All the prefixes under listRef. // You may call listAll() recursively on them. } for (item in items) { // All the items under listRef. } } .addOnFailureListener { // Uh-oh, an error occurred! }
Java
StorageReference listRef = storage.getReference().child("files/uid"); listRef.listAll() .addOnSuccessListener(new OnSuccessListener<ListResult>() { @Override public void onSuccess(ListResult listResult) { for (StorageReference prefix : listResult.getPrefixes()) { // All the prefixes under listRef. // You may call listAll() recursively on them. } for (StorageReference item : listResult.getItems()) { // All the items under listRef. } } }) .addOnFailureListener(new OnFailureListener() { @Override public void onFailure(@NonNull Exception e) { // Uh-oh, an error occurred! } });
Listenergebnisse paginieren
Die list() API begrenzt die Anzahl der zurückgegebenen Ergebnisse. list() bietet einen konsistenten Seitenaufruf und stellt ein pageToken zur Verfügung, mit dem Sie steuern können, wann zusätzliche Ergebnisse abgerufen werden.
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.
Das folgende Beispiel zeigt die Paginierung eines Ergebnisses:
Kotlin
fun listAllPaginated(pageToken: String?) { val storage = Firebase.storage val listRef = storage.reference.child("files/uid") // Fetch the next page of results, using the pageToken if we have one. val listPageTask = if (pageToken != null) { listRef.list(100, pageToken) } else { listRef.list(100) } // You'll need to import com.google.firebase.storage.component1 and // com.google.firebase.storage.component2 listPageTask .addOnSuccessListener { (items, prefixes, pageToken) -> // Process page of results processResults(items, prefixes) // Recurse onto next page pageToken?.let { listAllPaginated(it) } }.addOnFailureListener { // Uh-oh, an error occurred. } }
Java
public void listAllPaginated(@Nullable String pageToken) { FirebaseStorage storage = FirebaseStorage.getInstance(); StorageReference listRef = storage.getReference().child("files/uid"); // Fetch the next page of results, using the pageToken if we have one. Task<ListResult> listPageTask = pageToken != null ? listRef.list(100, pageToken) : listRef.list(100); listPageTask .addOnSuccessListener(new OnSuccessListener<ListResult>() { @Override public void onSuccess(ListResult listResult) { List<StorageReference> prefixes = listResult.getPrefixes(); List<StorageReference> items = listResult.getItems(); // Process page of results // ... // Recurse onto next page if (listResult.getPageToken() != null) { listAllPaginated(listResult.getPageToken()); } } }).addOnFailureListener(new OnFailureListener() { @Override public void onFailure(@NonNull Exception e) { // Uh-oh, an error occurred. } }); }
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 hindeuten, dass der Nutzer nicht die richtige Berechtigung hat. Weitere Informationen zu Fehlern finden Sie unter Fehler verarbeiten.