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
Gestire i dati con Azure Cosmos DB Data Explorer
Introduzione ai web component HTML
Recuperare automaticamente un utente e aggiungerlo ad un gruppo di Azure DevOps
Filtering sulle colonne in una QuickGrid di Blazor
Garantire la provenienza e l'integrità degli artefatti prodotti su GitHub
Usare i servizi di Azure OpenAI e ChatGPT in ASP.NET Core con Semantic Kernel
Creare una libreria CSS universale: Nav menu
Supportare lo HierarchyID di Sql Server in Entity Framework 8
Combinare Container Queries e Media Queries
Cancellare una run di un workflow di GitHub
Utilizzare WhenEach per processare i risultati di una lista di task
Inference di dati strutturati da testo con Semantic Kernel e ASP.NET Core Web API