Warning: file_get_contents(/data/phpspider/zhask/data//catemap/0/asp.net-core/3.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
C# 用于依赖项注入的ASP.NET核心多个实现_C#_Asp.net Core_Dependency Injection - Fatal编程技术网

C# 用于依赖项注入的ASP.NET核心多个实现

C# 用于依赖项注入的ASP.NET核心多个实现,c#,asp.net-core,dependency-injection,C#,Asp.net Core,Dependency Injection,有没有一种方法可以使用ASP.NET内核指定单个接口的多个实现?我可以在Ninject中这样做: ninjectKernel.Bind<DbContext>().To<OracleDbContext>().Named("UnitWork"); ninjectKernel.Bind<DbContext>().To<AppsDbContext>().Named("AppsWork"); 如果您的问题只针对DbContext,那么使用以下语句就很容易了

有没有一种方法可以使用ASP.NET内核指定单个接口的多个实现?我可以在Ninject中这样做:

ninjectKernel.Bind<DbContext>().To<OracleDbContext>().Named("UnitWork");
ninjectKernel.Bind<DbContext>().To<AppsDbContext>().Named("AppsWork");

如果您的问题只针对DbContext,那么使用以下语句就很容易了

public void ConfigureServices(IServiceCollection services)
{
    services.AddDbContext<OracleDbContext>(builder => builder.UseSqlServer(connectionString));
    services.AddDbContext<AppsDbContext>(builder => builder.UseSqlServer(connectionString));
}
如果您的问题与通用接口相关,那么只有当它是通用接口时才有可能。假设您有一个如下所示的界面:

public interface IRepository<T>
{
}
以及多种实现,如:

public class GenericRepository<User> : IRepository<User>
{
}

public class GenericRepository<Order> : IRepository<Order>
{
}
您只需要一行就可以注册多个实现

public void ConfigureServices(IServiceCollection services)
{
    // you can register them with any life time like that e.g. Singleton, Transient
    services.AddScoped(typeof(IRepository<>), typeof(GenericRepository<>));
}

我希望这有帮助

我还发现您可以在配置服务中这样配置OracleDBContext:

services.AddEntityFrameworkOracle()
  .AddDbContext<OracleDbContext>(option => option.UseOracle(Configuration["Data:OracleDbConnection"]), ServiceLifetime.Scoped)
  .AddDbContext<AppsDbContext>(option => option.UseOracle(Configuration["Data:AppsbConnection"]), ServiceLifetime.Scoped);