Cloud Storage for Firebase umożliwia wyświetlanie zawartości zasobnika Cloud Storage. Pakiety SDK zwracają zarówno elementy, jak i prefiksy obiektów w bieżącym odwołaniu do Cloud Storage.Cloud Storage
Projekty, które korzystają z interfejsu List API, wymagają Cloud Storage for Firebase reguł w wersji 2. Jeśli masz już projekt w Firebase, wykonaj czynności opisane w przewodniku po regułach bezpieczeństwa.
list() korzysta z
Google Cloud Storage interfejsu List API.
W Cloud Storage for Firebase używamy znaku / jako separatora, co pozwala nam
emulować semantykę systemu plików. Aby umożliwić wydajne przechodzenie przez duże,
hierarchiczne Cloud Storage zasobniki, interfejs List API zwraca prefiksy i
elementy oddzielnie. Jeśli na przykład prześlesz plik /images/uid/file1:
root.child('images').listAll()zwróci/images/uidjako prefiks.root.child('images/uid').listAll()zwróci plik jako element.
Pakiet SDK Cloud Storage for Firebase nie zwraca ścieżek obiektów, które zawierają 2
kolejne znaki / lub kończą się znakiem /. Rozważmy na przykład zasobnik, który zawiera te obiekty:
correctPrefix/happyItemwrongPrefix//sadItemlonelyItem/
Operacje na elementach w tym zasobniku dadzą te wyniki:
- Operacja na liście w katalogu głównym zwraca odwołania do
correctPrefix,wrongPrefixilonelyItemjakoprefixes. - Operacja na liście w
correctPrefix/zwraca odwołania docorrectPrefix/happyItemjakoitems. - Operacja na liście w
wrongPrefix/nie zwraca żadnych odwołań ponieważwrongPrefix//sadItemzawiera 2 kolejne znaki/. - Operacja na liście w
lonelyItem/nie zwraca żadnych odwołań ponieważ obiektlonelyItem/kończy się znakiem/.
Wyświetlanie wszystkich plików
Aby pobrać wszystkie wyniki dla katalogu, możesz użyć listAll.
Najlepiej używać tej metody w przypadku małych katalogów, ponieważ wszystkie wyniki są buforowane w pamięci.
Jeśli podczas procesu dodawane lub usuwane są obiekty, operacja może też nie zwrócić spójnego stanu.
W przypadku długiej listy użyj metody list() z paginacją, ponieważ listAll() buforuje wszystkie wyniki w pamięci.
Ten przykład pokazuje, jak używać 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! } });
Wyniki listy z paginacją
Interfejs list() API ogranicza liczbę zwracanych wyników. list()
zapewnia spójny widok strony i udostępnia token strony, który umożliwia kontrolowanie, kiedy pobierać dodatkowe wyniki.
Token strony koduje ścieżkę i wersję ostatniego elementu zwróconego w poprzednim wyniku. W kolejnym żądaniu z użyciem tokena strony wyświetlane są elementy, które znajdują się po tokenie strony.
Ten przykład pokazuje, jak podzielić wynik na strony:
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. } }); }
Obsługa błędów
list() i listAll() nie działają, jeśli nie zaktualizujesz reguł bezpieczeństwa do wersji 2. Jeśli widzisz ten błąd, zaktualizuj reguły bezpieczeństwa:
Listing objects in a bucket is disallowed for rules_version = "1".
Please update storage security rules to rules_version = "2" to use list.
Inne możliwe błędy mogą wskazywać, że użytkownik nie ma odpowiednich uprawnień. Więcej informacji o błędach znajdziesz w sekcji Obsługa błędów.