Per utilizzare Unity Container all'interno di un progetto ASP.NET MVC 5 è innanzitutto necessario installare il package NuGet Unity.Mvc e tutte le sue dipendenze, tramite l'interfaccia fornita da Visual Studio oppure tramite la command line del package manager digitando:
Install-Package Unity.Mvc
Una volta finita l'installazione possiamo notare due nuovi file all'interno della cartella App_Start ovvero:
- UnityConfig.cs
- UnityMvcActivator.cs
Il file UnityMvcActivator contiene un metodo Start che si occupa di settare durante la fase di startup Unity come dependency resolver all'interno della nostra Web application. Il file UnityConfig, invece, ci permette di registrare i vari tipi sul container grazie al metodo RegisterTypes. Per esempio, possiamo registrare un ipotetico servizio di configurazione come segue:
public static void RegisterTypes(IUnityContainer container) { container.RegisterType<IConfiguration, ConfigurationService>(); }
Completato questo primo step, terminiamo la configurazione del container registrando alcuni servizi/mapping utilizzati dal template base di ASP.NET MVC fornito da Visual Studio. Saltare questo step causerebbe dei crash nella nostra applicazione, causati dall'impossibilità di Unity di risolvere alcuni mapping e/o parametri di injection.
Completiamo il metodo RegisterTypes come segue:
public static void RegisterTypes(IUnityContainer container) { container.RegisterType<IConfiguration, ConfigurationService>(); container.RegisterType<UserManager<ApplicationUser>>( new TransientLifetimeManager()); container.RegisterType<IUserStore<ApplicationUser>, UserStore<ApplicationUser>>(new TransientLifetimeManager()); container.RegisterType<DbContext, ApplicationDbContext>( new TransientLifetimeManager()); container.RegisterType<AccountController>(new InjectionConstructor()); container.RegisterType<ManageController>(new InjectionConstructor()); }
A questo punto siamo poi pronti a modificare il costruttore dell'HomeController esplicitando tramite un parametro la sua dipendenza ad un oggetto di tipo IConfiguration:
public class HomeController : Controller { private IConfiguration conf; public HomeController(IConfiguration cnf) { if (cnf == null) throw new ArgumentNullException("IConfiguration is null"); conf = cnf; } public ActionResult Index() { ViewBag.Minimum = conf.GetMin(); ViewBag.Maximum = conf.GetMax(); return View(); } }
Per completezza riportiamo brevemente il codice dell'interfaccia IConfiguration e della sua implementazione:
public interface IConfiguration { int GetMin(); int GetMax(); } public class ConfigurationService : IConfiguration { public int GetMax() { return 1000; } public int GetMin() { return 10; } }
A questo punto possiamo realizzare la view associata all'action Index:
@{ ViewBag.Title = "Home Page"; } <div class="jumbotron"> <h1>From: @ViewBag.Minimum to @ViewBag.Maximum</h1> <p class="lead">DI made easy with Unity.Mvc</p> </div>
Se abbiamo eseguito correttamente gli step precedenti, il risultato sarà qualcosa di questo tipo:

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 nuovo modello GPT-4o con Azure OpenAI
Generare una User Delegation SAS in .NET per Azure Blob Storage
Eseguire script pre e post esecuzione di un workflow di GitHub
Usare i settings di serializzazione/deserializzazione di System.Text.Json di ASP.NET all'interno di un'applicazione non web
Rendere le variabili read-only in una pipeline di Azure DevOps
Configurare e gestire sidecar container in Azure App Service
Ordinare randomicamente una lista in C#
Utilizzare la funzione EF.Parameter per forzare la parametrizzazione di una costante con Entity Framework
Applicare un filtro per recuperare alcune issue di GitHub
Creare una libreria CSS universale: i bottoni
Generare la software bill of material (SBOM) in GitHub
Selettore CSS :has() e i suoi casi d'uso avanzati