Po przesłaniu pliku do referencji Cloud Storage możesz też pobrać i zaktualizować metadane pliku, np. wyświetlić lub zaktualizować typ treści. Pliki mogą też przechowywać niestandardowe pary klucz/wartość z dodatkowymi metadanymi pliku.
Pobieranie metadanych pliku
Metadane pliku zawierają typowe właściwości, takie jak name
, size
i contentType
(często określane jako typ MIME), a także mniej popularne, np. contentDisposition
i timeCreated
. Te metadane można pobrać z odwołania do Cloud Storage za pomocą metody getMetadata()
.
// Create reference to the file whose metadata we want to retrieve
final forestRef = storageRef.child("images/forest.jpg");
// Get metadata properties
final metadata = await forestRef.getMetadata();
// Metadata now contains the metadata for 'images/forest.jpg'
Aktualizowanie metadanych pliku
Metadane pliku możesz zaktualizować w dowolnym momencie po zakończeniu przesyłania pliku, korzystając z metody updateMetadata()
. Więcej informacji o tym, które właściwości można aktualizować, znajdziesz na pełnej liście. Aktualizowane są tylko właściwości określone w metadanych, a wszystkie pozostałe pozostają bez zmian.
// Create reference to the file whose metadata we want to change
final forestRef = storageRef.child("images/forest.jpg");
// Create file metadata to update
final newMetadata = SettableMetadata(
cacheControl: "public,max-age=300",
contentType: "image/jpeg",
);
// Update metadata properties
final metadata = await forestRef.updateMetadata(newMetadata);
// Updated metadata for 'images/forest.jpg' is returned
Aby usunąć właściwości metadanych z możliwością zapisu, przekaż wartość null
:
// Delete the cacheControl property
final newMetadata = SettableMetadata(cacheControl: null);
final metadata = await forestRef.updateMetadata(newMetadata);
Obsługa błędów
Istnieje wiele powodów, dla których podczas pobierania lub aktualizowania metadanych mogą wystąpić błędy. Może to być np. brak pliku lub brak uprawnień użytkownika do uzyskania dostępu do wybranego pliku. Więcej informacji o błędach znajdziesz w sekcji Obsługa błędów w dokumentacji.
Niestandardowe metadane
Możesz określić metadane niestandardowe za pomocą parametru customMetadata
konstruktora SettableMetadata
:
// Create reference to the file whose metadata we want to change
final forestRef = storageRef.child("images/forest.jpg");
// Create file metadata to update
final newCustomMetadata = SettableMetadata(
customMetadata: {
"location": "Yosemite, CA, USA",
"activity": "Hiking",
},
);
// Update metadata properties
final metadata = await forestRef.updateMetadata(newCustomMetadata);
// Updated metadata for 'images/forest.jpg' is returned
Możesz przechowywać dane dotyczące poszczególnych aplikacji w niestandardowych metadanych każdego pliku, ale zdecydowanie zalecamy używanie bazy danych (np. Firebase Realtime Database) do przechowywania i synchronizowania tego typu danych.
Właściwości metadanych pliku
Pełna lista właściwości metadanych pliku jest dostępna poniżej:
Właściwość | Typ | Czy można ustawić? |
---|---|---|
bucket |
String |
Nie |
generation |
String |
Nie |
metageneration |
String |
Nie |
metadataGeneration |
String |
Nie |
fullPath |
String |
Nie |
name |
String |
Nie |
size |
int |
Nie |
timeCreated |
DateTime |
Nie |
updated |
DateTime |
Nie |
md5Hash |
String |
Nie |
cacheControl |
String |
Tak |
contentDisposition |
String |
Tak |
contentEncoding |
String |
Tak |
contentLanguage |
String |
Tak |
contentType |
String |
Tak |
customMetadata |
Map<String, String> |
Tak |
Przesyłanie, pobieranie i aktualizowanie plików jest ważne, ale możliwość ich usuwania też. Dowiedz się, jak usuwać pliki z Cloud Storage.