gpt4 book ai didi

c# - 带有简单注入(inject)器共享 DbContext 的 ASP.NET Core DI

转载 作者:行者123 更新时间:2023-11-30 21:29:41 25 4
gpt4 key购买 nike

我正在建立一个 ASP.NET Core 项目并遵循基于 Tripod 的 CQRS 模式项目。我遵循了 Simple Injector integration guide 但有一点有点困惑......我想继续使用 UseInMemoryDatabase 选项进行测试并且只能找到使用 Core DI AddDbContext 方法。

我的 DbContext 实现了几个接口(interface):

public class EntityDbContext : DbContext,
IUnitOfWork,
IReadEntities,
IWriteEntities
{
// code here
}

我在 Startup.ConfigureServices 方法中这样做:

services.AddDbContext<EntityDbContext>(options => options.UseInMemoryDatabase("Snoogans"));

并在 Startup.Configure 方法中遵循 SI 集成指南:

container.Register<IUnitOfWork, xxxx>();
container.Register<IReadEntities, xxxx>();
container.Register<IWriteEntities, xxxx>();

我是否能够通过交叉线获得核心注册以插件到每个目标的目标,或者我应该直接在 SI 中注册上下文?

==我正在研究 Tripod 的原始概念:

var contextRegistration =
lifestyle.CreateRegistration<EntityDbContext, EntityDbContext>(container);
container.AddRegistration(typeof(EntityDbContext), contextRegistration);
container.AddRegistration(typeof(IUnitOfWork), contextRegistration);
container.AddRegistration(typeof(IWriteEntities), contextRegistration);
container.AddRegistration(typeof(IReadEntities), contextRegistration);

尝试用 SI 做所有事情,但不确定我如何获得 3 个接口(interface)的注册:

container.Register<EntityDbContext>(() =>
{
var optionsBuilder =
new DbContextOptionsBuilder<EntityDbContext>().UseInMemoryDatabase("Snoogans");
return new EntityDbContext(optionsBuilder.Options);
});
container.AddRegistration<IUnitOfWork>(xxxx);
container.AddRegistration<IReadEntities>(xxxx);
container.AddRegistration<IWriteEntities>(xxxx);

最佳答案

Am I able to get the Core registration over crosswire to plugin to the target for each of them or should I just be registering the context directly in SI?

两种方案都是可行的。您可以选择将 DbContext 直接注册到 Simple Injector 中。这通常是最明显的选择,因为您的 DbContext 是一个应用程序组件。应用程序组件通常应在您的应用程序容器(即简单注入(inject)器)中注册,而不是在框架的注册系统(即ServiceCollection)中注册。

然而,在注册 DbContext 时,它与 ASP.NET Core 配置系统有一些紧密的集成。这可以使在那里进行注册和简单地从 Simple Injector 交叉连接变得更加直接。这让配置系统可以控制 DbContext 的创建和销毁。这在执行 DbContext 池等操作时变得特别有值(value),因为此池功能与此配置和注册 API 紧密耦合。

通常,这两个选项都非常简单,但由于您的 DbContext 实现了多个您希望单独注册的接口(interface),这会导致您的注册变得更加复杂。如果您也使用内置的 DI 容器,情况也会如此,所以这不是 Simple Injector 特有的。

在您的情况下,纯粹在 Simple Injector 中进行注册将如下所示:

var reg = Lifestyle.Scoped.CreateRegistration(() =>
{
var optionsBuilder =
new DbContextOptionsBuilder<EntityDbContext>().UseInMemoryDatabase("Snoogans");
return new EntityDbContext(optionsBuilder.Options);
},
container);

container.AddRegistration<IUnitOfWork>(reg);
container.AddRegistration<IReadEntities>(reg);
container.AddRegistration<IWriteEntities>(reg);

如果您选择从 .NET Core 配置系统交叉连接 DbContext,您的配置将如下所示:

// Add to the built-in ServiceCollection
services.AddDbContext<EntityDbContext>(options => options.UseInMemoryDatabase("Snoogans"));

// Cross-wire in Simple Injector
container.CrossWire<EntityDbContext>(app);

// Pull that registration out of Simple Injector and use it for the interface registrations
var reg = container.GetRegistration(typeof(EntityDbContext)).Registration;

// Same as before
container.AddRegistration<IUnitOfWork>(reg);
container.AddRegistration<IReadEntities>(reg);
container.AddRegistration<IWriteEntities>(reg);

如果您不使用 Simple Injector,而是纯粹使用 .NET Core 的内置 DI 容器,则注册将如下所示:

services.AddDbContext<EntityDbContext>(options => options.UseInMemoryDatabase("Snoogans"));

services.AddScoped<IUnitOfWork>(c => c.GetRequiredService<EntityDbContext>());
services.AddScoped<IReadEntities>(c => c.GetRequiredService<EntityDbContext>());
services.AddScoped<IWriteEntities>(c => c.GetRequiredService<EntityDbContext>());

关于c# - 带有简单注入(inject)器共享 DbContext 的 ASP.NET Core DI,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/55214679/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com