对于依赖注入,常用的是通过构造函数注入对象,写法有时太繁琐,本篇介绍通过手动方式进行注入,在用法上更加方便些。

==========  原创作品    作者:未闻    出处:博客园  ==========

一、先了解依赖注入的几个生命周期

* Scoped:同一个Request请求使用同一个实例。

* Transient:瞬时,即每次注入、GetService都是新的实例。

* Singleton:单例模式,应用程序共享同一实例。

二、理论知识

* Startup.Configure函数中得到app.ApplicationServices,可以通过它的GetService方法获得Transient、Singleton的对象

* 可以通过HttpContextAccessor对象的HttpContext.RequestServices.GetService方法获得Scoped的对象

* 可以通过app.ApplicationServices.GetService<IHttpContextAccessor>()获得HttpContextAccessor对象。

三、具体实现步骤

1. 定义静态变量

public static IServiceProvider ServiceProvider { get; set; }

2. 在Startup的Configure方法中给ServiceProvider赋值

public void Configure(IApplicationBuilder app, IWebHostEnvironment env)
{
    //...
    GlobalContext.ServiceProvider = app.ApplicationServices;
}

3. 在Startup的ConfigureServices方法中启用HttpContextAccessor

public void ConfigureServices(IServiceCollection services)
{
    //...
    services.AddHttpContextAccessor();// 支持IHttpContextAccessor
}

4. 提供静态方法GetService<T>,完整示例代码

/// <summary>
/// 全局上下文
/// </summary>
public static class GlobalContext
{
    /// <summary>
    /// 注入对象服务提供类
    /// </summary>
    public static IServiceProvider ServiceProvider { get; set; }

    /// <summary>
    /// 手动获取注入的对象
    /// </summary>
    /// <typeparam name="T"></typeparam>
    /// <returns></returns>
    public static T GetService<T>() where T : class
    {
        return ServiceProvider?.GetService<IHttpContextAccessor>()?.HttpContext.RequestServices.GetService<T>();
    }
}

5. 调用示例

public interface IDependency
{
}
public abstract class BaseService<T> : IDependency
    where T : class, IDBContext
{
    protected SqlSugarClient _db => GlobalContext.GetService<T>().Client;
}
public class AuthService : BaseService<ISoye360DBContext>
{
    public bool IsClientExists(string clientId)
    {
        return _db.Queryable<Client>().First(c => c.ID == clientId && c.Enable) != null;
    }
}

 

版权声明:本文为yokeqi原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
本文链接:https://www.cnblogs.com/yokeqi/p/12730828.html