Gestire gli errori di Cloud Storage su Flutter

A volte, quando crei un'app, le cose non vanno come previsto e si verifica un errore.

In caso di dubbi, rileva l'eccezione generata dalla funzione e leggi il messaggio di errore.

final storageRef = FirebaseStorage.instance.ref().child("files/uid");
try {
  final listResult = await storageRef.listAll();
} on FirebaseException catch (e) {
  // Caught an exception from Firebase.
  print("Failed with error '${e.code}': ${e.message}");
}

Gestire i messaggi di errore

Esistono diversi motivi per cui possono verificarsi errori, tra cui il file non esiste, l'utente non ha l'autorizzazione per accedere al file desiderato o l'utente annulla il caricamento del file.

Per diagnosticare correttamente il problema e gestire l'errore, ecco un elenco completo di tutti gli errori che il nostro client genererà e di come si sono verificati.

Codice Descrizione
storage/unknown Si è verificato un errore sconosciuto.
storage/object-not-found Non esiste alcun oggetto nel riferimento desiderato.
storage/bucket-not-found Nessun bucket è configurato per Cloud Storage
storage/project-not-found Nessun progetto è configurato per Cloud Storage
storage/quota-exceeded È stata superata la quota del bucket Cloud Storage. Se hai il piano tariffario Spark, valuta l'upgrade al piano tariffario Blaze con pagamento a consumo. Se hai già il piano tariffario Blaze, contatta l'assistenza Firebase.

Importante: a partire dal 3 febbraio 2026, il piano tariffario Blaze sarà obbligatorio per utilizzare Cloud Storage, anche per i bucket predefiniti.
storage/unauthenticated L'utente non è autenticato. Autenticati e riprova.
storage/unauthorized L'utente non è autorizzato a eseguire l'azione desiderata. Controlla le regole di sicurezza per assicurarti che siano corrette.
storage/retry-limit-exceeded È stato superato il limite di tempo massimo per un'operazione (caricamento, download, eliminazione e così via). Riprova a caricare il video.
storage/invalid-checksum Il file sul client non corrisponde al checksum del file ricevuto dal server. Riprova a caricare il video.
storage/canceled L'utente ha annullato l'operazione.
storage/invalid-event-name È stato fornito un nome evento non valido. Deve essere uno tra [running, progress, pause]
storage/invalid-url È stato fornito un URL non valido a refFromURL(). Deve essere nel formato: gs://bucket/object o https://firebasestorage.googleapis.com/v0/b/bucket/o/object?token=<TOKEN>
storage/invalid-argument L'argomento passato a put() deve essere File, Blob o UInt8 Array. L'argomento passato a putString() deve essere una stringa non elaborata, Base64 o Base64URL.
storage/no-default-bucket Non è stato impostato alcun bucket nella proprietà storageBucket della configurazione.
storage/cannot-slice-blob Si verifica in genere quando il file locale è stato modificato (eliminato, salvato di nuovo e così via). Prova a caricare di nuovo il file dopo aver verificato che non sia stato modificato.
storage/server-file-wrong-size Il file sul client non corrisponde alle dimensioni del file ricevuto dal server. Riprova a caricare il video.