Azure Blob Storage è un servizio di archiviazione scalabile per oggetti, che consente di memorizzare grandi quantità di dati non strutturati, come documenti, immagini e file multimediali. Per garantire un accesso sicuro e controllato a questi dati, Azure offre le Shared Access Signatures (SAS), token che definiscono le autorizzazioni e la durata dell'accesso.
Una User Delegation SAS è un tipo di SAS firmata utilizzando le credenziali di Microsoft Entra ID, offrendo una sicurezza superiore rispetto alle SAS firmate con la chiave dell'account di archiviazione. Questo approccio riduce il rischio associato alla gestione diretta delle chiavi dell'account, poiché l'integrazione con le Managed Identities di Azure consente un'autenticazione sicura e senza necessità di memorizzare secrets. Le Managed Identities forniscono credenziali gestite automaticamente da Azure, migliorando la sicurezza e semplificando la gestione degli accessi alle risorse. Affinché tutto funzioni correttamente, l'utente dello sviluppatore utilizzato in Visual Studio o Visual Studio Code, oppure l'utenza dell'app su Azure (user o system identity), deve avere almeno il ruolo Storage Blob Data Reader a livello di account e di container.
Per creare una User Delegation SAS in .NET, prima di tutto assicuriamoci di avere i pacchetti Azure.Identity e Azure.Storage.Blobs installati nel progetto. Il primo passo è quello di ottnere una chiave di firma temporanea sulla base dell'utente impersonificato dall'app. Utilizziamo quindi prima DefaultAzureCredential e otteniamo poi la chiave per un lungo periodo, anche di un giorno.
var credential = new DefaultAzureCredential();
var blobServiceClient = new BlobServiceClient(new Uri($"https://{accountName}.blob.core.windows.net"), credential);
var userDelegationKey = await blobServiceClient.GetUserDelegationKeyAsync(DateTimeOffset.UtcNow, DateTimeOffset.UtcNow.AddDays(1)); L'idea è che questa chiave venga messa in cache in modo da tenerla disponibile e poter firmare velocemente i SAS.
Ottenuta la chiave (sul momento o dalla cache) possiamo procedere alla creazione della firma. Nell'esempio seguente diamo l'accesso all'interno container per un'ora.
var sasBuilder = new BlobSasBuilder
{
BlobContainerName = containerName,
Resource = "c", // "b" per un blob specifico
StartsOn = DateTimeOffset.UtcNow,
ExpiresOn = DateTimeOffset.UtcNow.AddHours(1)
};
sasBuilder.SetPermissions(BlobContainerSasPermissions.Read | BlobContainerSasPermissions.Write);
var sasToken = sasBuilder.ToSasQueryParameters(userDelegationKey, accountName).ToString();
var sasUri = new Uri($"{blobServiceClient.Uri}/{containerName}?{sasToken}"); Implementando questi passaggi, possiamo generare una User Delegation SAS in .NET, garantendo un accesso sicuro e controllato alle risorse di Azure Blob Storage senza esporre le chiavi dell'account.
Commenti
Per inserire un commento, devi avere un account.
Fai il login e torna a questa pagina, oppure registrati alla nostra community.
Approfondimenti
Gestione delle issue type con GitHub
Disabilitare le run concorrenti di una pipeline di Azure DevOps
Abilitare automaticamente il force push di un gruppo su Azure DevOps
Utilizzare il Null conditional assignment di C# 14
Usare i settings di serializzazione/deserializzazione di System.Text.Json di ASP.NET all'interno di un'applicazione non web
Eliminare record doppi in Sql Server
Rendere affidabile lo scale out su Azure App Service
Migrare applicazioni legacy nel cloud con Azure App Service Managed Instance
Usare il metodo nameof con un tipo generico in C# 14
Gestire trasferimenti cloud con Azure Storage Mover
Integrare OpenAI tramite Aspire




