一、使用DI注入
在之前的文章中已經講過DI的概念(.net 溫故知新:【7】IOC控制反轉,DI依賴注入),基于控制臺程序演示了DI依賴注入的使用,基于Microsoft.Extensions.DependencyInjection
完成。那在WebAPI中如何使用依賴注入呢?
首先新建一個WebAPI項目WebAPI_DI
,框架.net 7,其實 webapi 項目也是控制臺應用程序,只是在Asp.Net Core webapi框架中很多基礎工作已經幫我們封裝配置好了。
項目新建完成后在Program.cs 中自動生成如下代碼:
namespace WebAPI_DI
{
public class Program
{
public static void Main(string[] args)
{
var builder = WebApplication.CreateBuilder(args);
// Add services to the container.
builder.Services.AddControllers();
// Learn more about configuring Swagger/OpenAPI at https://aka.ms/aspnetcore/swashbuckle
builder.Services.AddEndpointsApiExplorer();
builder.Services.AddSwaggerGen();
var app = builder.Build();
// Configure the HTTP request pipeline.
if (app.Environment.IsDevelopment())
{
app.UseSwagger();
app.UseSwaggerUI();
}
app.UseHttpsRedirection();
app.UseAuthorization();
app.MapControllers();
app.Run();
}
}
}
builder.Services
則是幫我已經創建好的IServiceCollection
對象。
我們再新建一個測試類 DITestClass:
public class DITestClass
{
public int Add(int i, int n)
{
return i + n;
}
}
然后我們在builder.Services中進行注冊
最后我們在默認的WeatherForecastController
控制器里面加一個post方法,并用構造函數注入的方式將DITestClass注入進去。
swagger中調用測試:
二、[FromService] 注入
FromServicesAttribute 允許將服務直接注入到操作方法,而無需使用構造函數注入。
改屬性的作用主要針對我們在依賴注入初始化對象(該對象初始化很耗時),這個時候不管請求的api方法有沒有用到該對象都會等待很長時間。
所以使用FromService讓接口在請求的時候再注入,從而不影響其他接口
三、多層架構注入
在多層架構中我們如果引用了其他項目,要使用其他項目中的類,那么要在主項目中進行DI注入,這樣相當于所有其他模塊或者其他人寫的項目都需要主項目來維護注入,比如:
新建一個ClassLibrary1項目,Class1類,方法Sub:
我們在web項目里面引用ClassLibrary1項目,如果要使用Class1類就需要在 Programe.cs里面注冊
builder.Services.AddScoped(typeof(Class1));
那么有沒有方法讓他們自己的項目自己管理注冊呢,我們可以簡單改造一下
- 新建一個類庫,定義一個公共接口,安裝
Microsoft.Extensions.DependencyInjection
包
- 在ClassLibarary1里面定義實現接口類
public class ModulInit : IModuleInit
{
public void Init(IServiceCollection service)
{
//所有需要DI的在此處注入
service.AddScoped<Class1>();
}
}
- 在Programe.cs里面調用引用項目的注冊類
這樣其他項目也按照這種方式,在主項目中只要調用一次注冊管理。不過這是最簡單的方式,你也可以使用反射來查找引用的項目繼承了IModuleInit
的類,然后進行Init
方法調用,這樣會更優雅一些。
當然你還可以使用其他依賴注入框架來取代Microsoft.Extensions.DependencyInjection
,也學這個問題就不再是問題!