Using Dependency Injection with .NET Core Class Library (.NET Standard)
You don't have to do anything in your class library. Only the main application has a composition root (earliest point in an application lifecycle you can set up your object graph).
This happens in Startup.cs
in your ASP.NET Core application. There you also register your dependencies:
services.AddScoped<IUserManager,UserManager>();
That's it. Class libraries don't have a composition root. Neither they should, because you can't use them without an application and the IoC Container used is a choice of the application not of the library.
You can however provider convenience methods to do this registrations, like the AddXxx
method common in ASP.NET Core or some kind of module system, like in 3rd party IoC containern like Autofac or Castle Windsor.
Banketeshvar Narayan
Senior Technical Consultant, Microsoft MVP(1 time), C# Corner MVP(3 times) working experience on: .NET Core, C#, AngularJS, Angular, Dapper, Web Applications, SignalR, Blazor, SQL Server, Oracle...
Updated on December 26, 2020Comments
-
Banketeshvar Narayan over 3 years
I have gone through the link:
https://docs.microsoft.com/en-us/aspnet/core/mvc/controllers/dependency-injection
and learnt that how I can use dependency injection for Web API.
As mentioned in the above link I can use Startup (Startup.cs) class for dependency injection inside API layer. But how can achieve dependency injection for the .NET Core Class Library. Below is the screenshot how I am adding a class library.
And my project structure is
In the project “DataManagement.Repository” I have written a class “UserRepository” and in the project “DataManagement.Repository.Interfaces” written an Interface “IUserRepository”.
In the project “DataManagement.Business” I have written a class “UserManager”
class UserManager { private IUserManager _userManager; public UserManager(IUserManager userManager) { _userManager = userManager; } }
As you can see that I am trying to achieve dependency injection through the constructor.
But I am not sure that what changes need to be done for enabling dependency injection inside .NET Core Class Library (.NET Standard).
-
pejman over 7 yearsas u said in answer, if i add this dependency in
Startup.cs
om asp.net core application and then i add it's reference to .NetCore class library, i can use it? -
Tseng over 7 yearsYes, if you use dependency injection all the way (and never instantiate a service
new
) it will work -
pejman over 7 yearsI asked a question about this subject in
http://stackoverflow.com/questions/41342064/using-ihostingenvironment-in-netcore-library
plz give me help if u can. thanks -
WillC over 5 yearsDoes the .Api project then have to have a reference to the .Repository project in order to access the implementations of the .Repository interfaces?
-
Tseng over 5 years@WillC: Yea, since your composition root is the web application. You can abstract it a bit away, using Extension methods (such as ASP.NET Core does with the
.AddXyz
where you do the registrations within the .AddXyz` Method. -
Tseng over 5 yearsYou can additionally hide transitive dependencies with
<ProjectReference Include="..\ClassLibrary\ClassLibrary.csproj" PrivateAssets="All" />
(by addingPrivateAssets="All"
to the reference (in yourXyz.Extensions.DependencyInjection
project that contains the.AddXyz
method). This will hide the concrete implementations in your main application, sonew ServiceA()
will result in an error, so people won't accidentally. See github.com/dotnet/project-system/issues/… -
kuldeep almost 4 yearsmy composition root is an api, where i load a plugin (dynamically). Now this plugin uses some library as nuget, how can i in this situation do registration for dependencies required by library ?