Cloud Storage for Firebase ti consente di elencare i contenuti del tuo bucket Cloud Storage. Gli SDK restituiscono sia gli elementi che i prefissi degli oggetti nel riferimento Cloud Storage corrente.
I progetti che utilizzano l'API List richiedono Cloud Storage for Firebase Rules versione 2. Se disponi di un progetto Firebase esistente, segui i passaggi nella Guida alle regole di sicurezza .
list()
utilizza l' API Google Cloud Storage List . In Cloud Storage for Firebase utilizziamo /
come delimitatore, che ci consente di emulare la semantica del file system. Per consentire un attraversamento efficiente di bucket Cloud Storage gerarchici e di grandi dimensioni, l'API List restituisce prefissi ed elementi separatamente. Ad esempio, se carichi un file /images/uid/file1
,
-
root.child('images').listAll()
restituirà/images/uid
come prefisso. -
root.child('images/uid').listAll()
restituirà il file come elemento.
L'SDK Cloud Storage for Firebase non restituisce percorsi di oggetti che contengono due /
s consecutivi o che terminano con /
. Ad esempio, considera un bucket che contiene i seguenti oggetti:
-
correctPrefix/happyItem
-
wrongPrefix//sadItem
-
lonelyItem/
Le operazioni di elenco sugli elementi in questo bucket forniranno i seguenti risultati:
- L'operazione list alla radice restituisce i riferimenti a
correctPrefix
,wrongPrefix
elonelyItem
comeprefixes
. - L'operazione di elenco in
correctPrefix/
restituisce i riferimenti acorrectPrefix/happyItem
comeitems
. - L'operazione di elenco su
wrongPrefix/
non restituisce alcun riferimento perchéwrongPrefix//sadItem
contiene due/
s consecutivi. - L'operazione di elenco su
lonelyItem/
non restituisce alcun riferimento perché l'oggettolonelyItem/
termina con/
.
Elenca tutti i file
Puoi utilizzare listAll
per recuperare tutti i risultati per una directory. È meglio utilizzarlo per directory di piccole dimensioni poiché tutti i risultati vengono memorizzati nel buffer. L'operazione potrebbe inoltre non restituire uno snapshot coerente se gli oggetti vengono aggiunti o rimossi durante il processo.
Per un elenco di grandi dimensioni, utilizzare il metodo impaginato list()
poiché listAll()
memorizza nel buffer tutti i risultati.
L'esempio seguente mostra listAll
.
Kotlin+KTX
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! } });
Risultati dell'elenco di impaginazione
L'API list()
pone un limite al numero di risultati restituiti. list()
fornisce una visualizzazione di pagina coerente ed espone un pageToken che consente il controllo su quando recuperare risultati aggiuntivi.
Il pageToken codifica il percorso e la versione dell'ultimo elemento restituito nel risultato precedente. In una richiesta successiva che utilizza pageToken, vengono visualizzati gli elementi che seguono il pageToken.
L'esempio seguente mostra l'impaginazione di un risultato:
Kotlin+KTX
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. } }); }
Gestire gli errori
list()
e listAll()
falliscono se non hai aggiornato le regole di sicurezza alla versione 2. Aggiorna le tue regole di sicurezza se vedi questo errore:
Listing objects in a bucket is disallowed for rules_version = "1".
Please update storage security rules to rules_version = "2" to use list.
Altri possibili errori potrebbero indicare che l'utente non dispone dell'autorizzazione corretta. Ulteriori informazioni sugli errori sono disponibili nella sezione Gestire gli errori .