Autofac & ASP.NET Core: почему ASP.NET Core не может получить доступ к методу ConfigureContainer при запуске, наследуя от StartupBase?

Описание:

Я создаю приложение ASP.NET Core с использованием Autofac, поэтому я следую документации, предоставленной для него: https://autofaccn.readthedocs.io/en/latest/integration/aspnetcore.html, должен быть довольно простой путь для подражания, но у меня есть проблема, мой класс Statup наследуется от Microsoft.AspNetCore.Hosting.StartupBase, что заставляет меня реализовать следующее:

public abstract class StartupBase : IStartup
{
      protected StartupBase();

      public abstract void Configure(IApplicationBuilder app);
      public virtual void ConfigureServices(IServiceCollection services);
      public virtual IServiceProvider CreateServiceProvider(IServiceCollection services);
}

пока все хорошо, мой класс Statup выглядит так

public class Startup : StartupBase
{
  readonly IHostingEnvironment hostingEnvironment;

  public Startup(IHostingEnvironment hostingEnvironment)
  {
     //some stuff here
  }

  public override void ConfigureServices(IServiceCollection services)
  {
     //some other stuff here
  }

  // https://autofaccn.readthedocs.io/en/latest/integration/aspnetcore.html
  public void ConfigureContainer(ContainerBuilder builder)
  {
     builder.RegisterModule(new AutofacModule());        
  }

  public override void Configure(IApplicationBuilder app)
  {
     //more stuff here
  }     
}    

и Program.cs, просто для примера это пример

public class Program
{
  public static void Main(string[] args)
  {
    // The ConfigureServices call here allows for
    // ConfigureContainer to be supported in Startup with
    // a strongly-typed ContainerBuilder.
    var host = new WebHostBuilder()
        .UseKestrel()
        .ConfigureServices(services => services.AddAutofac())
        .UseContentRoot(Directory.GetCurrentDirectory())
        .UseIISIntegration()
        .UseStartup<Startup>()
        .Build();

    host.Run();
  }
}

Проблема:

Как только приложение запускается, оно должно попасть в метод ConfigureContainer, но это не так, и я не знаю почему, а это означает, что я не могу внедрить что-либо, зарегистрированное в классе AutofactModule, мне удается решить эту проблему, но я хочу знать, что происходит за кадром,

Fix:

Я удалил наследство из StartupBase и все прошло нормально

Теория:

Я подозреваю, что каким-то образом Autofac в.UserStartup получает базовый класс и пытается извлечь из него методы, но я не могу доказать это и не могу найти правильные слова для его поиска. Может кто-нибудь объяснить мне, почему простое наследование является проблемой здесь?

1 ответ

Решение

Таким образом, это на самом деле скорее вещь Microsoft, чем вещь Autofac - в рамках Microsoft.AspNetCore.Hosting пространство имен является StartupLoader Класс Github Здесь. Это то, что на самом деле выбирает, какие методы вызываются. У него есть интересная особенность (выбор дизайна) - не вызывать методы Autofac - на github возникла пара связанных с этим проблем, хотя в целом они были закрыты, так как кажется, что это выбор дизайна, который они не собираются менять.

Другие вопросы по тегам