依赖性注入是一种技术,它允许我们注入一个特定类的依赖对象,而不是直接创建这些实例。 使用依赖注入的好处显而易见,它通过放松模块间的耦合,来增强系统的可维护性和可测试性。 依赖注入允许
依赖性注入是一种技术,它允许我们注入一个特定类的依赖对象,而不是直接创建这些实例。
使用依赖注入的好处显而易见,它通过放松模块间的耦合,来增强系统的可维护性和可测试性。
依赖注入允许我们修改具体实现,而不必改变依赖于它们的依赖类型。
ASP.net core 很重视依赖注入技术。ASP.net core 中内置的依赖注入提供功能模块,并不像 StructureMap 和 Ninject 等ioc(控制反转)容器那样功能丰富,但它速度快,易于配置,而且易于使用。我们可以使用它在 ASP.Net Core 中注入框架服务和应用程序服务。
关于依赖注入和控制反转的有关知识可以参考:设计模式。
我们将介绍三种不同方法来解决 asp.net Core 6 中的依赖项。
本文中提供的代码示例均默认运行在 Visual Studio 2022。
我们在 Visual Studio 2022 中创建一个 ASP.NET Core 项目。按照以下步骤在 Visual Studio 2022 中创建一个新的 ASP.NET Core WEB api 6 项目。
这将在 Visual Studio 2022 中创建一个新的 ASP.NET Core 6 Web API 项目。我们将在本文的后续部分中使用该项目来说明解析依赖项。
现在创建以下接口:
public interface ICustomFileLogger
{
public string Text { get; set; }
public void Log(string message);
}
为简单起见,我们给出一个最小的表示。
CustomFileLogger
类实现 ICustomFileLogger
接口,代码如下:
public class CustomFileLogger : ICustomFileLogger
{
public string Text { get; set; }
public void Log(string message)
{
// 自己的实现逻辑
}
}
如果使用的是 ASP.NET 5,可以在 ConfigureServices
方法中注册一个 ICustomFileLogger
类型的实例作为一个 Scoped
服务。如果使用的是 ASP.NET 6,则直接在 Program.cs 文件中注册。
services.AddScoped<ICustomFileLogger, CustomFileLogger>();
接下来,创建一个名为 DefaultController
的 API 控制器并输入以下代码:
[Route("api/[controller]")]
[ApiController]
public class DefaultController : ControllerBase
{
private ICustomFileLogger _logger;
public DefaultController(ICustomFileLogger logger)
{
_logger = logger;
if(string.IsNullOrEmpty(_logger.Text))
_logger.Text = DateTime.UtcNow.ToString();
}
[HttpGet]
public string Get()
{
return "Hello World!";
}
}
注意这里是如何使用构造函数注入的。DefaultController
类的构造函数接受 ICustomFileLogger
类型的实例作为参数。
当需要在多个方法中使用注入的实例时,我们应该使用构造函数注入。如果只需要在特定的动作方法中使用实例,最好在动作方法中注入实例,而不是使用构造函数注入。
以下代码片段说明了如何实现动作方法注入。
[HttpPost("Log")]
public IActionResult Log([FromServices] ICustomFileLogger customFileLogger)
{
// 自己的实现逻辑
return Ok();
}
我们有时候可能经常需要在控制器中注入许多不同的服务。如果使用构造函数注入,则必须在构造函数中指定多个参数。所以,这种场景下,有一个更好的解决方案,就是使用 IServiceProvider
。
我们可以使用 IServiceCollection
接口来创建依赖项注入容器。一旦创建了容器,IServiceCollection
实例就会组合成一个 IServiceProvider
实例。我们可以使用此实例来解析服务。
我们可以将 IServiceProvider
类型的实例注入到类的任何方法中。您还可以利用 IApplicationBuilder
接口的 ApplicationServices
属性和 HttpContext
类的 RequestServices
属性来检索 IServiceProvider
实例。
以下代码说明了如何注入 IServiceProvider
类型的实例:
public class DefaultController : Controller
{
private IServiceProvider _provider;
public DefaultController(IServiceProvider provider)
{
_provider = provider;
}
}
我们可以在操作方法中使用以下代码,来检索需要的任何服务实例。
ICustomFileLogger logger = (ICustomFileLogger)_provider.GetService(typeof(ICustomFileLogger));
注意 IServiceProvider
的 GetService
方法是如何用来检索服务实例的。
我们可以使用 HttpContext
类的 RequestServices
属性来检索 IServiceProvider
类型的实例,然后使用该实例调用 GetService
方法。
以下代码展示了HttpContext
类如何做到检索实例:
ICustomFileLogger logger = (ICustomFileLogger)HttpContext.RequestServices.GetService(typeof(ICustomFileLogger));
依赖性注入是一种通过放松耦合来增强代码维护和可测试性的方法。
我们可以使用 ASP.NET Core 中内置的依赖注入支持来创建模块化、精简和干净的应用程序,同时也使应用程序更容易维护和测试。
参考资料:
1. 设计模式
到此这篇关于三种方法解决ASP.NET Core 6中的依赖项的文章就介绍到这了。希望对大家的学习有所帮助,也希望大家多多支持编程网。
--结束END--
本文标题: 三种方法解决ASP.NET Core 6中的依赖项
本文链接: https://lsjlt.com/news/158104.html(转载时请注明来源链接)
有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341
2023-05-21
2023-05-21
2023-05-21
2023-05-21
2023-05-20
2023-05-20
2023-05-20
2023-05-20
2023-05-20
2023-05-20
回答
回答
回答
回答
回答
回答
回答
回答
回答
回答
0