HttpContext имеет значение null при создании ApplicationDbContext - PullRequest
0 голосов
/ 03 апреля 2020

Я пытаюсь реализовать многопользовательский режим в своем приложении Core 3.1 MVC. Я вижу примеры, такие как ниже, но когда я запускаю свое приложение, HttpContext имеет значение null, и я не понимаю, почему. Единственное отличие состоит в том, что я использую ApplicationDbContext, но, насколько я понимаю, он все равно наследует от DbContext ...

public class PlaylistContext : DbContext
{
    private int _tenantId;
    private string _tenantHost;

    public DbSet<Playlist> Playlists { get; set; }
    public DbSet<Song> Songs { get; set; }

    public PlaylistContext(DbContextOptions<PlaylistContext> options,
                           IHttpContextAccessor accessor)
        : base(options)
    {
        _tenantHost = accessor.HttpContext.Request.Host.Value;
    }

    protected override void OnModelCreating(ModelBuilder modelBuilder)
    {
        var connection = Database.GetDbConnection();
        using (var command = connection.CreateCommand())
        {
            connection.Open();

            command.CommandText = "select ID from Tenants where Host=@Host";
            command.CommandType = CommandType.Text;

            var param = command.CreateParameter();
            param.ParameterName = "@Host";
            param.Value = _tenantHost;

            command.Parameters.Add(param);
            _tenantId = (int)command.ExecuteScalar();
            connection.Close();
        }

        foreach (var type in GetEntityTypes())
        {
            var method = SetGlobalQueryMethod.MakeGenericMethod(type);
            method.Invoke(this, new object[] { modelBuilder });
        }

        base.OnModelCreating(modelBuilder);
    }

    // Other methods follow
}

Мой код

public ApplicationDbContext(
            DbContextOptions<ApplicationDbContext> options,
            IHttpContextAccessor http,
            ILogger<ApplicationDbContext> logger,
            ITenantService tenantService
            )
            : base(options)
        {
            _http = http; // <-- _http.HttpContext is null
            _logger = logger;
            _tenantService = tenantService;
        }

Мои службы

public void ConfigureServices(IServiceCollection services)
        {
            services.AddDbContext<ApplicationDbContext>(options => {
                options.UseSqlite(Configuration.GetConnectionString("DefaultConnection"));
                options.EnableSensitiveDataLogging(true);
            });

            services.AddDefaultIdentity<IdentityUser>(options => options.SignIn.RequireConfirmedAccount = true)
                .AddRoles<IdentityRole>()
                .AddEntityFrameworkStores<ApplicationDbContext>();

            services.AddControllersWithViews()
            .AddRazorRuntimeCompilation()
            .AddNewtonsoftJson(options=>{
                options.SerializerSettings.ReferenceLoopHandling = ReferenceLoopHandling.Ignore;
            });

            services.AddRazorPages();

            services.AddMultiTenancy()
                .WithResolutionStrategy<HostResolutionStrategy>()
                .WithStore<TenantStore>();

            services.AddScoped<ITenantService, TenantService>();

        }

Ответы [ 2 ]

0 голосов
/ 03 апреля 2020

Имейте в виду, что OnModelCreating будет вызываться один раз даже для нового контекста. Также это будет выполнено вне HttpRequest, поэтому HttpContext имеет значение null.

services.AddDefaultIdentity<IdentityUser>(options => options.SignIn.RequireConfirmedAccount = true) .AddRoles<IdentityRole>() .AddEntityFrameworkStores<ApplicationDbContext>();

0 голосов
/ 03 апреля 2020

Попробуйте добавить эту строку в регистрацию услуг:

services.AddSingleton<IHttpContextAccessor, HttpContextAccessor>();

или

services.AddHttpContextAccessor();

Эта ссылка показывает способы доступа HttpContext:

https://docs.microsoft.com/en-us/aspnet/core/fundamentals/http-context?view=aspnetcore-3.1

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...