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
Disabilitare automaticamente un workflow di GitHub (parte 2)
Persistere la ChatHistory di Semantic Kernel in ASP.NET Core Web API per GPT
Utilizzare Azure AI Studio per testare i modelli AI
Visualizzare le change sul plan di Terraform tramite le GitHub Actions
Registrare servizi multipli tramite chiavi in ASP.NET Core 8
Gestire domini wildcard in Azure Container Apps
Testare l'invio dei messaggi con Event Hubs Data Explorer
Ottimizzare il mapping di liste di tipi semplici con Entity Framework Core
Evitare il flickering dei componenti nel prerender di Blazor 8
Creare un'applicazione React e configurare Tailwind CSS
Sfruttare gli embedding e la ricerca vettoriale con Azure SQL Database
Creazione di plugin per Tailwind CSS: espandere le Funzionalità del Framework