gpt4 book ai didi

asp.net - Autofac 无法从 asp.net 5 中的程序集扫描中解析类型

转载 作者:行者123 更新时间:2023-12-04 12:46:30 25 4
gpt4 key购买 nike

我们有一个 dnx46 Web 项目,它在启动期间使用 autofac 程序集扫描来注册类型。我们的 project.json 依赖项包括:

"Autofac.Configuration": "4.0.0-rc1-268",
"Autofac.Extensions.DependencyInjection": "4.0.0-rc1-177",
"Autofac.Extras.CommonServiceLocator": "3.2.0",
"Microsoft.AspNet.Hosting": "1.0.0-rc1-final",
"Microsoft.AspNet.IISPlatformHandler": "1.0.0-rc1-final",
"Microsoft.AspNet.Mvc": "6.0.0-rc1-final",
"Microsoft.AspNet.Mvc.TagHelpers": "6.0.0-rc1-final",
"Microsoft.AspNet.Mvc.ViewFeatures": "6.0.0-rc1-final",
"Microsoft.AspNet.Server.Kestrel": "1.0.0-rc1-final",
"Microsoft.AspNet.Session": "1.0.0-rc1-final",
"Microsoft.AspNet.StaticFiles": "1.0.0-rc1-final",
"Microsoft.AspNet.Tooling.Razor": "1.0.0-rc1-final",
"Microsoft.Extensions.Configuration.EnvironmentVariables": "1.0.0-rc1-final",
"Microsoft.Extensions.Configuration.Json": "1.0.0-rc1-final",
"Microsoft.Extensions.Logging": "1.0.0-rc1-final",
"Microsoft.Extensions.Logging.Console": "1.0.0-rc1-final",
"Microsoft.Extensions.Logging.Debug": "1.0.0-rc1-final",
"Microsoft.VisualStudio.Web.BrowserLink.Loader": "14.0.0-rc1-final",
"Newtonsoft.Json": "8.0.3"

我们的 startup.cs ConfigureServices 方法如下所示:
public IServiceProvider ConfigureServices(IServiceCollection services)
{
services.AddSingleton(serviceType => Configuration);
services.AddInstance<Microsoft.Extensions.Configuration.IConfiguration>(Configuration);

services.AddCaching();
services.AddSession();
services.AddMvc();

var builder = new ContainerBuilder();

var assemblies = Directory.GetFiles(<ourBinDirectoryPath>, "*.dll", SearchOption.TopDirectoryOnly).Select(Assembly.LoadFrom);

foreach (var assembly in assemblies)
{
builder.RegisterAssemblyTypes(assembly).Where(t => t.Name.EndsWith("Service") || t.Name.EndsWith("Repository") || t.Name.EndsWith("DataContext")).AsSelf().AsImplementedInterfaces();
builder.RegisterAssemblyTypes(assembly).Where(t => !t.Name.EndsWith("Service") && !t.Name.EndsWith("Repository") && !t.Name.EndsWith("DataContext")).AsSelf().AsImplementedInterfaces().InstancePerDependency();
}

builder.Populate(services);
var container = builder.Build();

return container.Resolve<IServiceProvider>();
}

我们的过程是我们构建了几个项目,这些项目将这个项目需要的 dll 放入自定义 bin 文件夹中。在启动时,我们扫描这些程序集以向 Autofac 注册类型。我们在一个概念验证项目中做到了这一点,并且没有问题。但是在我们的新项目中,我们有以下问题:
  • 如果您尝试在 Controller 构造函数中解析服务,它
    抛出一个错误,表明 Microsoft 依赖注入(inject)不能
    解决服务。不知道为什么它不使用 Autofac
    供应商在这里。
  • 如果我们在启动时手动解析单个类型以及我们的程序集扫描,我们将在 Controller 构造中收到错误,指示 Autofac 无法解析服务(此处使用 Autofac 提供程序,但仍然找不到我们的类型)。
  • 如果我在它返回到 ConfigureServices 之前检查构建器和容器,它似乎已经注册了我们所有的类型。但是,如果我更改 Controller 以注入(inject) IServiceProvider,然后尝试从中解析服务,它会准确地使用 Autofac 提供程序,但我总是返回 null(未找到服务)。

  • 在尝试了很多事情之后,我把我们的概念验证项目复制到我们的新解决方案中(以防我们在设置新项目时错过了一些小的设置或其他东西),不良行为仍在继续。我开始认为我们的程序集引入了一些错误(因为这些是复制后唯一改变的东西),但是 Autofac 在扫描期间不会抛出错误,而是没有使用它正确扫描的类型.

    编辑 1

    我创建并发布了 very simplified example重现了我遇到的问题。您应该能够将其拉下来并运行它以重现错误。您应该在主 Controller 构造函数中收到一个错误,指示服务解析失败。

    注意:运行此示例时,它会执行一个 .bat 文件,该文件将来自域项目的输出 dll 放入您的用户配置文件 .nuget 文件夹中。

    编辑 2

    根据 @Travis Illig 的推荐将接口(interface)拆分为抽象文件夹.一旦我这样做了,解决方案就开始起作用了。我们将它拆分到我们的“真实”项目中,但它不起作用。仍在尝试找出原因。

    编辑 3

    所以终于让我们的项目再次工作。问题最终是几件事:
  • 我们的 Web 项目中列出了一个抽象项目依赖项,我们还从该程序集中加载和扫描 dll(双重加载)。 (我认为这是个大问题。)
  • 我们的 NuGet 版本很糟糕,所以我认为它们没有正确加载。我们使用的是 1.0.0-1,这是一种无效的预发布格式。将其更新为 1.0.0-b1,事情似乎开始变得更好。

  • 这让我花了更长的时间才弄清楚,此时我最大的问题是 Autofac 会默默地失败。我真的希望它会爆炸并给我一些调试输出或表明存在问题的东西。相反,一切似乎都可以正常扫描和加载,但是当你去使用容器时,什么都解决不了。

    最佳答案

    程序集的加载顺序可能是由于未加载必备程序集而无法加载某些类型的顺序。

    例如,假设您有包含接口(interface) IComponent 的程序集 A .还说您有包含类 Component 的程序集 B实现 IComponent .如果首先加载程序集 B,类型 Component将无法加载,因为它实现的接口(interface)未定义。

    在进行类型扫描时,Autofac 会尝试尽可能安全,并且在遇到无法加载的类型时不会爆炸。您可以在 scanning registration source 中看到它使用一种特殊的安全方法进行加载。

    在您的尖峰代码中,我敢打赌要加载的程序集要少得多,因此您最终以正确的顺序加载了东西。快乐的意外。当您进入较大的项目时,更容易控制加载顺序并导致此类问题。

    关于asp.net - Autofac 无法从 asp.net 5 中的程序集扫描中解析类型,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/36226457/

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