Come sappiamo, Blazor ci permette di leggere la configurazione da un file appsettings.json, che per default si trova nella cartella wwwroot.
Tuttavia, più che un file statico, alle volte è molto più conveniente utilizzare un vero e proprio endpoint di ASP.NET Core, perché magari vogliamo leggere queste informazioni da un database o da altri sorgenti, o in generale perché è più semplice manipolarle lato server.
Immaginiamo allora di avere un controller simile al seguente:
[ApiController] [Route("[controller]")] public class ConfigController : ControllerBase { [HttpGet] public object Get() { // questa impostazione potrebbe essere letta da un database return new { WelcomeMessage = "Hello from the server" }; } }
Lato Blazor, possiamo implementare la logica per leggere questo endpoint allo startup e usarne il contenuto per popolare la configurazione, istanziando un HttpClient nella classe Program come nell'esempio:
public class Program { public static async Task Main(string[] args) { var builder = WebAssemblyHostBuilder.CreateDefault(args); var httpClient = new HttpClient { BaseAddress = new Uri(builder.HostEnvironment.BaseAddress) }; builder.Services.AddScoped(sp => httpClient); using var serverConfig = await httpClient.GetAsync("/config"); using var stream = await serverConfig.Content.ReadAsStreamAsync(); builder.Configuration.AddJsonStream(stream); await builder.Build().RunAsync(); } }
Nel codice in alto, abbiamo sfruttato lo stesso HttpClient che registriamo nell'IoC container per effettuare una chiamata all'endpoint che abbiamo appena esposto, aggiungendo poi il contenuto alla configurazione tramite il metodo AddJsonStream, fondendolo con quanto già presente in appsettings.json.
A questo punto, potremo accedere alle impostazioni provenienti dal server in maniera del tutto analoga al file statico:
@page "/" @inject Microsoft.Extensions.Configuration.IConfiguration Configuration <h1>@this.Configuration.GetSection("WelcomeMessage").Value</h1>
Commenti
Per inserire un commento, devi avere un account.
Fai il login e torna a questa pagina, oppure registrati alla nostra community.
Approfondimenti
Filtrare i dati di una QuickGrid in Blazor con una drop down list
Creare un'applicazione React e configurare Tailwind CSS
Aprire una finestra di dialogo per selezionare una directory in WPF e .NET 8
Utilizzare Container Queries nominali
Bloccare l'esecuzione di un pod in mancanza di un'artifact attestation di GitHub
Limitare le richieste lato server con l'interactive routing di Blazor 8
Creazione di plugin per Tailwind CSS: espandere le funzionalità del framework dinamicamente
Creare una libreria CSS universale: Clip-path
Evitare il flickering dei componenti nel prerender di Blazor 8
Cambiare la chiave di partizionamento di Azure Cosmos DB
Ottimizzare il mapping di liste di tipi semplici con Entity Framework Core
Generare la software bill of material (SBOM) in GitHub
I più letti di oggi
- Tutorial Entity Framework 6
- Tutorial Entity Framework
- Tutorial HTML5
- RT @aspitalia Partecipa al nostro evento #RCD4, fai un RT e sarai estratto per 1 copia di #sl3guidacompleta! http://u.aspitalia.com/bw
- Migliorare l'organizzazione delle risorse con Azure Policy
- Configurare più site su unico web role di Windows Azure
- Windows Phone 8 Developer Day - Milano
- ReBuild 2020 Live - Online
- ASPItalia.com Network: si aggiungono LINQItalia.com e SilverlightItalia.com
- Rilasciata la versione 1.0 di ASP.NET MVC