處理 Flutter 中的 Cloud Storage 錯誤

有時在開發應用程式的過程中 發生錯誤!

有疑慮時,請擷取函式擲回的例外狀況 查看錯誤訊息的內容

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}");
}

處理錯誤訊息

導致發生錯誤的原因有很多,包括檔案 非現有檔案、使用者無權存取所需檔案,或 使用者取消上傳檔案。

為了正確診斷問題並處理錯誤,請參考以下完整清單, 用戶端發生的所有錯誤,以及這些錯誤發生的方式

程式碼 說明
storage/unknown 發生不明錯誤。
storage/object-not-found 所需的參照中沒有物件。
storage/bucket-not-found Cloud Storage 未設定任何值區
storage/project-not-found 未設定 Cloud Storage 專案
storage/quota-exceeded 您的 Cloud Storage 值區已超過配額。如果您使用的是免付費方案,請升級至付費方案,如果您使用付費方案,請與 Firebase 支援團隊聯絡。
storage/unauthenticated 使用者尚未通過驗證,請進行驗證並再試一次。
storage/unauthorized 使用者未獲授權,無法執行所需動作,請檢查您的安全性規則,確認其設定正確無誤。
storage/retry-limit-exceeded 已超過某項作業 (上傳、下載、刪除等) 的時間上限。請重新上傳。
storage/invalid-checksum 用戶端上的檔案與伺服器接收的檔案檢查碼不符。請重新上傳。
storage/canceled 使用者已取消作業。
storage/invalid-event-name 提供的事件名稱無效。必須是 [runningprogresspause] 其中之一
storage/invalid-url 提供給 refFromURL() 的網址無效。格式必須為:gs://bucket/objecthttps://firebasestorage.googleapis.com/v0/b/bucket/o/object?token=<TOKEN>
storage/invalid-argument 傳遞至 put() 的引數必須是 FileBlobUInt8 陣列。傳遞至 putString() 的引數必須是原始、Base64Base64URL 字串。
storage/no-default-bucket 設定的 storageBucket 屬性中未設好任何值區。
storage/cannot-slice-blob 當本機檔案變更 (刪除、再次儲存等) 時,通常就會發生這種情形。確認檔案未變更後,請嘗試重新上傳。
storage/server-file-wrong-size 用戶端上的檔案與伺服器接收的檔案大小不符。請重新上傳。