首页 > 解决方案 > 带有私有 NuGet 包的 Blazor 依赖项注入和 EF/DbContext

问题描述

我正在尝试设置一个 Blazor 项目,以使其可通过许多其他项目重用,并且在理解 Blazor 的 DI 系统如何与 NuGet 包一起使用时遇到问题。

简而言之,我构建了一个简单的 Blazor 应用程序作为错误报告/请求的票务系统。它通过输入表单(构建为组件)收集简单信息,并通过实体框架和连接字符串(存储在 AppSettings.JSON 中)将票证上传到 SQL Server 数据库。DbContext 通过 AddDbContextFactory 注入到票务应用的 DI 系统中。这一切都在解决方案中完美运行。

我的目标是:我想打包这个票务系统,并以最少的设置在我的其他应用程序中重复使用它。在其他应用程序中,我想重用“AddTicket”组件,它会简单地接受一些简单的报告数据并更新票务数据库。

作为测试,我在我的机器上本地将票务应用打包为 NuGet 包。我将它导入到一个单独的主机应用程序中。但是,我必须在主机应用程序中重新创建连接字符串和依赖注入(使用上下文工厂和所有内容)才能使包正常工作。

我的问题是,当我构建自己的 NuGet 包时,我不了解 Blazor 的 DI 系统是如何工作的,而且我不了解 Startup.cs 中的依赖注入流程与 NuGet 包中的内容。

我只是一个简单的、可重用的表单和提交组件,所有 EF 和数据库逻辑都以最简单的方式内置在其中,我可以放入十几个外部项目中。

构建 NuGet 包的最佳方法是什么,这样我就不需要在这种情况下进行额外的依赖注入?如果我必须额外进入宿主应用程序的 DI 系统,我该如何让它尽可能简单?

标签: entity-frameworkasp.net-coredependency-injectionblazorblazor-server-side

解决方案


当我创建一个具有注入的库时。在我的库中,我创建了一个静态类并为IServiceCollection

public static class ServiceCollectionExtensions
{
    public static void AddBlazorSyncServer(this IServiceCollection services)
    {
        services.AddScoped<ILogger, Logger<LoggingBroker>>();
        services.AddScoped<ILoggingBroker, LoggingBroker>();
        services.AddScoped<IDateTimeBroker, DateTimeBroker>();
        services.AddTransient<ISyncDatabaseBroker, SyncDatabaseBroker>();
        ...


    }
}

注意:在我的示例SyncDatabaseBroker中是DbContext

public partial class SyncDatabaseBroker : DbContext, ISyncDatabaseBroker

这使用户更容易在他们的代码库中进行设置。数据库的处理方式必须稍有不同。当我想管理迁移或共享连接字符串时,我使用这种方法:

Program.cs(图书馆消费服务器)

...
var migrationsAssembly = typeof(Program).Assembly.FullName;

builder.Services.AddDbContext<ApplicationDbContext>(
    options => options.UseSqlServer(
        connectionString,
        dbOpts => dbOpts.MigrationsAssembly(migrationsAssembly)));


builder.Services.AddDbContext<SyncDatabaseBroker>(
    options => options.UseSqlServer(
        connectionString, 
        dbOpts => dbOpts.MigrationsAssembly(migrationsAssembly)));
...

builder.Services.AddBlazorSyncServer();

然后我可以将控制台命令用于迁移:

Add-Migration InitialApplicationSchema -Context ApplicationDbContext -OutputDir Data/Migrations/Application
Add-Migration InitialSyncSchema -Context SyncDatabaseBroker -OutputDir Data/Migrations/Sync

Update-Database -Context ApplicationDbContext
Update-Database -Context SyncDatabaseBroker 


推荐阅读