zoukankan      html  css  js  c++  java
  • .NETCore3.1-DI-实现手动注入对象

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

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

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

    * 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;
        }
    }
  • 相关阅读:
    Online ddl 工具之pt-online-schema-change
    【MySql】mysql 慢日志查询工具之mysqldumpslow
    赶集网mysql开发36条军规
    MySQL数据库高并发优化配置
    mysql的表分区
    mysql 如果处理货币金钱类型
    bootstrab table+表格 select可编辑完整实例
    mongoDb 给表添加+ 删除字段
    mongoDb +Java+springboot
    java+数据库+D3.js 实时查询人物关系图
  • 原文地址:https://www.cnblogs.com/yokeqi/p/12730828.html
Copyright © 2011-2022 走看看