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
Gestire la query string nell'output cache di ASP.NET Core
Effettuare chiamate con versioning da Blazor ad ASP.NET Core
Leggere la configurazione da Azure KeyVault con logica di retry in ASP.NET Core
Usare le variabili per personalizzare gli stili CSS
ChatOps con GitHub
Pubblicare la documentazione di un repository con GitHub Pages
Raggruppare i parametri di una minimal API in un singolo oggetto in ASP.NET Core
Effettuare test di carico con Azure Load Testing
Effettuare delete massive con Entity Framework Core 7
Sfruttare l'output cache di ASP.NET Core 7 con i controller
Aggiungere le issue di più repository in una board in GitHub
Health monitoring con Azure Container App
I più letti di oggi
- 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!
- 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!
- .NET Conference Italia 2022 - Milano e Online