Dopo aver caricato un file nel riferimento Cloud Storage, puoi anche recuperare e aggiornare i metadati del file, ad esempio per aggiornare il tipo di contenuto. I file possono anche archiviare coppie chiave/valore personalizzate con metadati aggiuntivi.
Recuperare i metadati dei file
I metadati dei file contengono proprietà comuni come Name, SizeBytes e ContentType (spesso indicato come tipo MIME), oltre ad alcune meno comuni come ContentDisposition e CreationTimeMillis. Questi
metadati possono essere recuperati da un Cloud Storage riferimento utilizzando il
GetMetadataAsync metodo.
// Create reference to the file whose metadata we want to retrieve StorageReference forestRef = storageRef.Child("images/forest.jpg"); // Get metadata properties forestRef.GetMetadataAsync().ContinueWithOnMainThread(task => { if (!task.IsFaulted && !task.IsCanceled) { StorageMetadata meta = task.Result; // do stuff with meta } });
Aggiornare i metadati dei file
Puoi aggiornare i metadati dei file in qualsiasi momento dopo il completamento del caricamento utilizzando il metodo UpdateMetadataAsync, che accetta un oggetto MetadataChange.
Per ulteriori informazioni sulle proprietà che possono essere aggiornate, consulta l'elenco completo. Vengono aggiornate solo le proprietà specificate nei metadati, tutte le altre rimangono invariate.
// Create reference to the file whose metadata we want to change StorageReference forestRef = storageRef.Child("images/forest.jpg"); // Create file metadata to update var newMetadata = new MetadataChange(); newMetadata.CacheControl = "public,max-age=300"; newMetadata.ContentType = "image/jpeg"; // Update metadata properties forestRef.UpdateMetadataAsync(newMetadata).ContinueWithOnMainThread(task => { if (!task.IsFaulted && !task.IsCanceled) { // access the updated meta data StorageMetadata meta = task.Result; } });
Puoi eliminare le proprietà dei metadati scrivibili passando la stringa vuota:
// Create file metadata to update var newMetadata = new MetadataChange(); newMetadata.ContentType = ""; // Update metadata properties forestRef.UpdateMetadataAsync(newMetadata).ContinueWithOnMainThread(task => { if (!task.IsFaulted && !task.IsCanceled) { StorageMetadata meta = task.Result; // meta.ContentType should be an empty string now } });
Gestire gli errori
Esistono diversi motivi per cui potrebbero verificarsi errori durante il recupero o l'aggiornamento dei metadati, tra cui il file non esiste o l'utente non dispone dell'autorizzazione per accedere al file desiderato. Per ulteriori informazioni sugli errori, consulta la sezione Gestire gli errori della documentazione.
Metadati personalizzati
Puoi specificare i metadati personalizzati come Dictionary<string, string>.
var newMetadata = new MetadataChange { CustomMetadata = new Dictionary<string, string> { {"location", "Yosemite, CA, USA"}, {"activity", "Hiking"} } }; // UpdateMetadataAsync
Puoi archiviare i dati specifici dell'app per ogni file nei metadati personalizzati, ma ti consigliamo vivamente di utilizzare un database (ad esempio Firebase Realtime Database) per archiviare e sincronizzare questo tipo di dati.
Proprietà dei metadati dei file
Di seguito è riportato un elenco completo delle proprietà dei metadati di un file:
| Proprietà | Tipo | Modificabile in MetadataChange |
|---|---|---|
Bucket |
string |
NO |
Generation |
string |
NO |
MetadataGeneration |
string |
NO |
Path |
string |
NO |
Name |
string |
NO |
SizeBytes |
long |
NO |
CreationTimeMillis |
long |
NO |
UpdatedTimeMillis |
long |
NO |
CacheControl |
string |
SÌ |
ContentDisposition |
string |
SÌ |
ContentEncoding |
string |
SÌ |
ContentLanguage |
string |
SÌ |
ContentType |
string |
SÌ |
DownloadUrl |
Uri |
NO |
DownloadUrls |
IList<Uri> |
NO |
CustomMetadataKeys |
IEnumerable<string> |
SÌ |
Passaggi successivi
Il caricamento, il download e l'aggiornamento dei file sono importanti, ma lo è anche la possibilità di rimuoverli. Scopriamo come eliminare i file da Cloud Storage.