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
Eseguire chiamate hedging gRPC con ASP.NET Core 6
Test reporting in un workflow di GitHub
Aggiungere le issue di più repository in una board in GitHub
Installazione di una PWA Blazor
Chiamare un endpoint ASP.NET Core protetto da Certificate Authentication
Consumare un endpoint generico in Blazor
Utilizzare .NET Framework con le Azure Function in modalità isolata
Utilizzare i WebSocket con Azure API Management
Utilizzare le Promise in Javascript - seconda parte
Leggere il valore di un header della richiesta in ASP.NET Core 6
Impostare il contenuto dell'head all'interno di ogni pagina Blazor
I più letti di oggi
- 3 metodi JavaScript che ogni applicazione web dovrebbe contenere - Parte 2
- Effettuare l'upload di un file via FTP con la libreria FluentFTP di .NET
- Sfruttare la local cache del browser tramite gli ETag in #aspnetcore https://aspit.co/cfc di @crad77 #webapi #aspnetmvc #blazor #cache
- Controllare se un branch esiste nel remote con un workflow di GitHub
- Universal App and Web Live - Online