Cloud Storage for Firebase umożliwia wyświetlenie zawartości zasobnika Cloud Storage. Zestawy SDK zwracają zarówno elementy, jak i prefiks obiektów w bieżącym odwołaniu Cloud Storage.
Projekty, które korzystają z interfejsu List API, wymagają Cloud Storage for Firebase reguł w wersji 2. Jeśli masz już projekt Firebase, wykonaj czynności opisane w przewodniku po regułach zabezpieczeń.
list()
korzysta z Google Cloud Storage interfejsu List API.
W Cloud Storage for Firebase używamy znaku /
jako ogranicznika, 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 1 plik /images/uid/file1
,
root.child('images').listAll()
zwróci/images/uid
jako przedrostek.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 /.
. Załóżmy, że masz zasobnik z tymi obiektami:
correctPrefix/happyItem
wrongPrefix//sadItem
lonelyItem/
Operacje wyświetlania listy elementów w tym zasobniku dadzą te wyniki:
- Operacja wyświetlania listy w katalogu głównym zwraca odwołania do elementów
correctPrefix
,wrongPrefix
ilonelyItem
jakoprefixes
. - Operacja listy w przypadku
correctPrefix/
zwraca odwołania docorrectPrefix/happyItem
jakoitems
. - Operacja listy w miejscu
wrongPrefix/
nie zwraca żadnych odwołań, ponieważwrongPrefix//sadItem
zawiera 2 kolejne znaki/
. - Operacja na liście w miejscu
lonelyItem/
nie zwraca żadnych odwołań, ponieważ obiektlonelyItem/
kończy się znakiem/
.
Wyświetlanie listy wszystkich plików
Aby pobrać wszystkie wyniki dla katalogu, możesz użyć listAll
.
Najlepiej sprawdza się w przypadku małych katalogów, ponieważ wszystkie wyniki są buforowane w pamięci.
Operacja może też nie zwrócić spójnego zrzutu, jeśli w trakcie procesu dodawane lub usuwane są obiekty.
W przypadku długiej listy użyj metody stronicowanej list()
, ponieważ listAll()
buforuje wszystkie wyniki w pamięci.
Poniższy przykład pokazuje listAll
.
Web
import { getStorage, ref, listAll } from "firebase/storage"; const storage = getStorage(); // Create a reference under which you want to list const listRef = ref(storage, 'files/uid'); // Find all the prefixes and items. listAll(listRef) .then((res) => { res.prefixes.forEach((folderRef) => { // All the prefixes under listRef. // You may call listAll() recursively on them. }); res.items.forEach((itemRef) => { // All the items under listRef. }); }).catch((error) => { // Uh-oh, an error occurred! });
Web
// Create a reference under which you want to list var listRef = storageRef.child('files/uid'); // Find all the prefixes and items. listRef.listAll() .then((res) => { res.prefixes.forEach((folderRef) => { // All the prefixes under listRef. // You may call listAll() recursively on them. }); res.items.forEach((itemRef) => { // All the items under listRef. }); }).catch((error) => { // Uh-oh, an error occurred! });
Podział wyników listy na strony
Interfejs list()
API ogranicza liczbę zwracanych wyników. list()
zapewnia spójny widok strony i udostępnia element pageToken, który umożliwia kontrolowanie, kiedy pobierać dodatkowe wyniki.
Parametr pageToken koduje ścieżkę i wersję ostatniego elementu zwróconego w poprzednim wyniku. W kolejnym żądaniu z użyciem parametru pageToken wyświetlane są elementy, które występują po tym parametrze.
Poniższy przykład pokazuje, jak podzielić wyniki na strony za pomocą parametru async/await
.
Web
import { getStorage, ref, list } from "firebase/storage"; async function pageTokenExample(){ // Create a reference under which you want to list const storage = getStorage(); const listRef = ref(storage, 'files/uid'); // Fetch the first page of 100. const firstPage = await list(listRef, { maxResults: 100 }); // Use the result. // processItems(firstPage.items) // processPrefixes(firstPage.prefixes) // Fetch the second page if there are more elements. if (firstPage.nextPageToken) { const secondPage = await list(listRef, { maxResults: 100, pageToken: firstPage.nextPageToken, }); // processItems(secondPage.items) // processPrefixes(secondPage.prefixes) } }
Web
async function pageTokenExample(){ // Create a reference under which you want to list var listRef = storageRef.child('files/uid'); // Fetch the first page of 100. var firstPage = await listRef.list({ maxResults: 100}); // Use the result. // processItems(firstPage.items) // processPrefixes(firstPage.prefixes) // Fetch the second page if there are more elements. if (firstPage.nextPageToken) { var secondPage = await listRef.list({ maxResults: 100, pageToken: firstPage.nextPageToken, }); // processItems(secondPage.items) // processPrefixes(secondPage.prefixes) } }
Obsługuj błędy
list()
i listAll()
zwracają odrzuconą obietnicę, jeśli nie zaktualizujesz reguł bezpieczeństwa do wersji 2. Jeśli zobaczysz ten błąd, uaktualnij reguły zabezpieczeń:
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.