Le Azure Function sono un servizio della piattaforma Microsoft Azure che permettono di definire piccole funzioni nei più svariati linguaggi e di poter scalare all'infinito, adattandosi automaticamente alle esigenze.
Nel caso del mondo .NET se utilizziamo funzioni per il .NET Framework godiamo della possibilità di usare la classe statica ConfigurationManager, se invece usiamo .NET Core, non esiste nessun membro statico, ma siamo noi a dover sfruttare il sistema builtin nel modo più appropriato, poiché nel caso delle function, non esiste un unico entry point come siamo abituati nei normali applicativi. Nel nostro codice, quindi, è necessario simulare un comportamento di configurazione univoca, utilizzando manualmente il ConfigurationBuilder, come nell'esempio.
public static class ConfigurationUtility { private static readonly Lazy<IConfiguration> _configuration = new Lazy<IConfiguration>(BuildConfiguration); public static IConfiguration Configuration => _configuration.Value; private static IConfigurationRoot BuildConfiguration() { var configurationBuilder = new ConfigurationBuilder() .AddJsonFile("appsettings.json", optional: true) .AddEnvironmentVariables(); return configurationBuilder.Build(); } }
La classe statica dispone di una proprietà in lazy loading che carica la configurazione al primo utilizzo di ConfigurationUtility.Configuration. Possiamo notare che viene aggiunto un provider basato su file json, qualora ne avessimo uno a disposizione, ma, cosa più importante, viene chiamato AddEnvironmentVariables per incorporare le variabili d'ambienti provenienti dal pannello di configurazione delle Azure Function.

Usando una sintassi basata sui due punti possiamo definire in modo flat anche sezioni e strutture ad albero. Nell'esempio la chiave Email:To può essere recuperata come segue.
IConfigurationSection section = ConfigurationUtility.Configuration.GetSection("email"); string to = section["to"];
Così facendo non c'è distinzione nell'approccio alla configurazione, indipendentemente dal linguaggio o dal framework che stiamo utilizzando.
Commenti
Per inserire un commento, devi avere un account.
Fai il login e torna a questa pagina, oppure registrati alla nostra community.
Approfondimenti
Ottenere un token di accesso per una GitHub App
Configurare e gestire sidecar container in Azure App Service
Supportare la sessione affinity di Azure App Service con Application Gateway
Anonimizzare i dati sensibili nei log di Azure Front Door
Migliorare la sicurezza dei prompt con Azure AI Studio
Estrarre dati randomici da una lista di oggetti in C#
Recuperare App Service cancellati su Azure
Triggerare una pipeline su un altro repository di Azure DevOps
Creare un webhook in Azure DevOps
Eliminare una project wiki di Azure DevOps
Gestione dell'annidamento delle regole dei layer in CSS
Persistere la ChatHistory di Semantic Kernel in ASP.NET Core Web API per GPT
I più letti di oggi
- Eseguire query in contemporanea con EF
- Fissare una versione dell'agent nelle pipeline di Azure DevOps
- .NET Aspire per applicazioni distribuite
- Utilizzare Locust con Azure Load Testing
- Autenticazione di git tramite Microsoft Entra ID in Azure DevOps
- Repaint, Reflow e Compositing: Come Funziona il Rendering nel Browser
- ecco tutte le novità pubblicate sui nostri siti questa settimana: https://aspit.co/wkly buon week-end!
- ecco tutte le novità pubblicate sui nostri siti questa settimana: https://aspit.co/wkly buon week-end!