为什么通过HttpContext.RequestServices
或IServiceProvider
请求服务被认为是不良实践?我可以在各个地方阅读到这种说法:
建议使用构造函数注入而不是使用RequestServices获取它。
我的想法恰恰相反。尽可能使用RequestServices。让我解释一下为什么。 我想尽可能使控制器保持简洁,因此创建单独的服务。这样,我的控制器就很清晰:
public class MyController : Controller
{
public MyController(IMyServices MyServices){}
public async Task<IActionResult> GetSomething(int parameter)
{
return await this.MyServices.SomeMethod(parameter);
}
}
所有服务都继承自一个基类,该基类包含有关管理权限、缓存SQL请求等的逻辑...。
通过使用构造函数方法,我得到了一个非常复杂的调用基类系统:
public class MyBaseService
{
public MyBaseService(ILogger Logger, AppDbContext Context, IMemoryCache Cache) { }
public bool HasRight(string right) { return true; }
public bool IsLoggedIn() { return true; }
}
public class MyServices : MyBaseService
{
public MyServices(ILogger Logger, AppDbContext Context, IMemoryCache Cache) : base(Logger, Context, Cache)
{
}
}
但是通过GetRequiredService
,我简化了基于构造函数的调用:
public class MyBaseService2
{
private ServiceProvider _ServiceProvider;
public MyBaseService2(IServiceProvider ServiceProvider)
{
}
protected ILogger Logger { get { return this._ServiceProvider.GetRequiredService<ILogger>(); } }
protected AppDbContext Context { get { return this._ServiceProvider.GetRequiredService<AppDbContext>(); } }
protected IMemoryCache Cache { get { return this._ServiceProvider.GetRequiredService<IMemoryCache>(); } }
public bool HasRight(string right) { return true; }
public bool IsLoggedIn() { return true; }
}
public class MyServices2 : MyBaseService2
{
public MyServices2(IServiceProvider ServiceProvider) : base(ServiceProvider)
{
}
}
是的,BaseService包含更多的代码,但是当我需要在BaseService中添加其他服务时,无需修复每个类的基本构造函数调用。此外,我所有的服务都有更简单的构造函数(只需IServiceProvider
)。
如果我违反构造函数方法,那么如果调用ServiceProvider.GetRequiredService
来获取MyServices,是否会有性能损失,如果它们的生命周期是Scoped。