Autofac 通用装饰器正在复制组件

本文关键字:复制 组件 Autofac | 更新日期: 2023-09-27 18:32:43

我发现了我认为可能是Autofac中的错误,但我想看看是否有人有可能的解决方案或解决方法,以便我可以完成这项工作。

基本上我已经设置了一个通用装饰器,它工作正常。问题是,一旦我使用配置委托调用BeginLifetimeScope(),它就会错误地解析同一类型的多个组件。如果我不使用带有 BeginLifetimeScope() 的配置委托,那么它可以正常工作。遗憾的是,我需要向我的子范围添加其他依赖项,因此不使用配置委托不是一个选项。

下面是一个演示问题的示例:

var builder = new ContainerBuilder();
builder.RegisterType<Dependency>()
    .Named<IDependency<object>>("service");
builder.RegisterGenericDecorator(
    typeof(Decorator<>), typeof(IDependency<>), "service", "decorated");
var container = builder.Build();
// Returns 1
var scope1 = container.BeginLifetimeScope();
Console.WriteLine(
    scope1.ResolveNamed<IEnumerable<IDependency<object>>>("decorated").Count());
// Returns 2 - notice the configAction doesn't even have to do anything
var scope2 = container.BeginLifetimeScope(r => { });
Console.WriteLine(
    scope2.ResolveNamed<IEnumerable<IDependency<object>>>("decorated").Count());

这是我的假货类型:

interface IDependency<T> { }
class Dependency : IDependency<object> { }
class Decorator<T> : IDependency<T> {}

任何帮助将不胜感激!

Autofac 通用装饰器正在复制组件

它看起来确实是一个错误。作为解决方法,我最终执行以下操作:

var param = new TypedParameter(typeof(IDecoratorDependency), new DecoratorDependency());
var decorated = scope.ResolveNamed<IEnumerable<IDependency<object>>>("decorated", param);

这对于我的用例来说已经足够了。但是,此方法不灵活,因为它只允许我向根对象提供参数,在本例中为 Decorator<T> ,但不允许其任何依赖项。