ASP.NETCore依赖注入DI容器的方法实现

2023-03-19 17:03:45 依赖 容器 注入

ASP.net core 是一个跨平台、高性能的框架,它提供了一种依赖注入(DI)容器,用于管理应用程序中的对象和服务。DI 是一种设计模式,它通过将对象的创建和管理分离出来,实现了应用程序的松耦合,提高了代码的可维护性、可测试性和可扩展性。

一、注册服务

在 ASP.net core 中,DI 容器使用 IServiceCollection 接口来注册服务。IServiceCollection 接口定义了一组方法,用于向 DI 容器中注册服务。常用的注册方法包括:

  • AddTransient<TService, TImplementation>():向 DI 容器中注册一个瞬时生命周期的服务。每次请求该服务时,都会创建一个新的实例。
  • AddScoped<TService, TImplementation>():向 DI 容器中注册一个作用域生命周期的服务。每次请求该服务时,都会创建一个新的实例,并在同一作用域内共享该实例。
  • AddSingleton<TService, TImplementation>():向 DI 容器中注册一个单例生命周期的服务。在应用程序的整个生命周期中,只会创建一个实例,并在整个应用程序中共享该实例。

除了上述常用的注册方法,IServiceCollection 还提供了一些其他的注册方法,例如:

  • AddTransient():向 DI 容器中注册一个瞬时生命周期的服务。服务的实现类型由 TService 的实现类型决定。
  • AddScoped():向 DI 容器中注册一个作用域生命周期的服务。服务的实现类型由 TService 的实现类型决定。
  • AddSingleton():向 DI 容器中注册一个单例生命周期的服务。服务的实现类型由 TService 的实现类型决定。

除了注册服务的方法之外,IServiceCollection 还提供了一些其他的方法,例如:

  • TryAddTransient<TService, TImplementation>():尝试向 DI 容器中注册一个瞬时生命周期的服务。如果该服务已经存在,则不进行注册。
  • TryAddScoped<TService, TImplementation>():尝试向 DI 容器中注册一个作用域生命周期的服务。如果该服务已经存在,则不进行注册。
  • TryAddSingleton<TService, TImplementation>():尝试向 DI 容器中注册一个单例生命周期的服务。如果该服务已经存在,则不进行注册。

示例代码:

public void ConfigureServices(IServiceCollection services)
{
    // 注册一个瞬时生命周期的服务
    services.AddTransient<IMyService, MyService>();

    // 注册一个作用域生命周期的服务
    services.AddScoped<IMyScopedService, MyScopedService>();

    // 注册一个单例生命周期的服务
    services.AddSingleton<IMySingletonService, MySingletonService>();
}

二、解析依赖

在 ASP.Net Core 中,DI 容器使用 IServiceProvider 接口来解析依赖,获取服务的实例。IServiceProvider 接口定义了一个 GetService 方法,用于获取指定类型的服务实例。示例代码:

public class MyController : Controller
{
    private readonly IMyService _myService;

    public MyController(IServiceProvider serviceProvider)
    {
        // 通过 IServiceProvider 解析依赖
        _myService = serviceProvider.GetService<IMyService>();
    }

    public IActionResult Index()
    {
        var message = _myService.GetMessage();
        return View(model: message);
    }
}

在上面的代码中,MyController 类的构造函数接收一个 IServiceProvider 实例作为参数,通过 IServiceProvider.GetService() 方法获取 IMyService 实例。在 Index 方法中,调用 _myService.GetMessage() 方法获取消息,并将其传递给视图。

三、实现自定义的服务提供程序

asp.net Core 中,可以通过实现 IServiceProvider 接口来实现自定义的服务提供程序。IServiceProvider 接口只定义了一个 GetService 方法,用于获取指定类型的服务实例。示例代码:

public class MyServiceProvider : IServiceProvider
{
    public object GetService(Type serviceType)
    {
        if (serviceType == typeof(IMyService))
        {
            return new MyService();
        }
        else if (serviceType == typeof(IMyScopedService))
        {
            return new MyScopedService();
        }
        else if (serviceType == typeof(IMySingletonService))
        {
            return new MySingletonService();
        }
        else
        {
            return null;
        }
    }
}

在上面的代码中,MyServiceProvider 类实现了 IServiceProvider 接口,并重写了 GetService 方法。在 GetService 方法中,根据服务类型返回相应的服务实例。

要使用自定义的服务提供程序,可以在 Startup 类的 ConfigureServices 方法中调用 services.AddSingleton<IServiceProvider, MyServiceProvider>() 方法将其注册到 DI 容器中。示例代码:

public void ConfigureServices(IServiceCollection services)
{
    // 注册自定义的服务提供程序
    services.AddSingleton&lt;IServiceProvider, MyServiceProvider&gt;();
}

四、总结

ASP.net Core 的 DI 容器提供了一种简单、灵活的方式来管理应用程序中的对象和服务。通过注册服务、解析依赖和实现自定义的服务提供程序,可以实现应用程序的松耦合,提高代码的可维护性、可测试性和可扩展性。在开发 ASP.NET Core 应用程序时,应该充分利用 DI 容器,提高代码的质量和效率。

到此这篇关于ASP.NET Core依赖注入DI容器的方法实现的文章就介绍到这了,更多相关ASP.NET Core依赖注入DI容器内容请搜索以前的文章或继续浏览下面的相关文章希望大家以后多多支持!

相关文章