Quando una class library contiene uno o più HttpModule, l'attivazione tramite web.config può risultare molto scomoda, perchè in ogni progetto in cui la utilizziamo dobbiamo ricordarci di aggiungere le opportune righe di configurazione.
Esiste un metodo che invece ci permette di incapsulare tutta questa logica all'interno della libreria, così che l'utilizzatore possa limitarsi solo ad aggiungere la reference. Immaginiamo, per esempio di aver realizzato il modulo seguente, che effettua automaticamente il login come administrator nel caso in cui la richiesta provenga dall'host locale:
public class SampleModule : IHttpModule { public void Init(HttpApplication context) { context.AuthenticateRequest += (s, e) => { if (HttpContext.Current.Request.IsLocal) { var identity = new GenericIdentity("admin"); HttpContext.Current.User = new GenericPrincipal(identity, new[] { "administrators" }); } }; } public void Dispose() { } }
Per poter registrare questo modulo dobbiamo innanzitutto aggiungere alla libreria il package WebActivatorEx tramite NuGet. A questo punto non dobbiamo far altro che creare un metodo senza parametri all'interno di una classe statica, in cui registrare il modulo:
namespace DemoLibrary { public static class Initializer { public static void Setup() { DynamicModuleUtility.RegisterModule(typeof(SampleModule)); } } }
La classe DynamicModuleUtility proviene dal package Microsoft.Web.Infrastructure che viene installato come dipendenza da WebActivatorEx. Manca solo l'ultimo step, ossia quello di decorare l'assembly con l'attributo PreApplicationStartMethod e referenziare il metodo appena creato:
[assembly: WebActivatorEx.PreApplicationStartMethod( typeof(DemoLibrary.Initializer), "Setup")]
Come anticipato, a questo punto sarà sufficiente aggiungere una reference a questa library da un qualsiasi progetto ASP.NET e, sia che esso girì in modalità classic pipeline che integrated, il nostro modulo verrà attivato in fase di startup ed eseguito a ogni richiesta.
Commenti
Per inserire un commento, devi avere un account.
Fai il login e torna a questa pagina, oppure registrati alla nostra community.
Approfondimenti
Utilizzare il metodo TrackGraph per impostare lo stato degli oggetti in un grafo in Entity Framework Core
Produrre e condividere una variabile tra step in una pipeline YAML di Azure DevOps
Inizializzazione asincrona di un servizio allo startup di un'applicazione Blazor
Eseguire integration test di un progetto ASP.NET Core
Creare un web server locale con LiveReload
Proteggere le risorse Azure da cancellazioni involontarie
Creare un radio button per Blazor
Eseguire lo shutdown pulito di un'applicazione ASP.NET Core
Effettuare il multi-checkout nelle pipeline di Azure DevOps
Modificare la modalità di esecuzione delle query con Include in Entity Framework Core 5
Sfruttare al massimo Kubernetes con Azure DevOps
Tracciare le modifiche apportate in Azure Blob Storage
I più letti di oggi
- Creare un web server locale con LiveReload
- Effettuare l'upload di un file da Blazor su Azure Blob Storage
- ecco tutte le novità pubblicate sui nostri siti questa settimana: https://aspit.co/wkly buon week-end!
- Modificare la modalità di esecuzione delle query con Include in Entity Framework Core 5
- Visual Basic 2019
- 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!
- Tracciabilità dei work item nel ciclo di vita del software con Azure DevOps