2

我正在尝试使用结构映射引导程序https://github.com/NancyFx/Nancy.Bootstrappers.StructureMap引导 nancyfx

这是我的设置:

        protected override void ConfigureApplicationContainer(IContainer container)
    {

        container.Configure(x =>
        {
            x.ForSingletonOf<IRazorConfiguration>()
                .Use<DefaultRazorConfiguration>();

           x.ForSingletonOf<ISessionContainer>().Use<SessionContainer>();

           x.For<IRepository>().LifecycleIs(new HttpContextLifecycle()).Use<Repository>();

            x.Scan(scanner=>
            {
                scanner.TheCallingAssembly();
                scanner.AddAllTypesOf<IRepository>();

            });
        });
        base.ConfigureApplicationContainer(container);
    }

 public interface IRepository
{
   void Save();
}

   public class Repository:IRepository
{

   ISessionContainer _session;
   public Repository(ISessionContainer container)
   {
       _session = container;
   }

   public void Save()
   {

   }
}

当我使用var repo = ObjectFactory.GetInstance<IRepository>();时,我得到了这个异常:

StructureMap Exception Code:  202
No Default Instance defined for PluginFamily Infrastructure.IRepository, Infrastructure, Version=1.0.0.0, Culture=neutral, PublicKeyToken=null 
4

2 回答 2

6

我想帮助你摆脱黑客......你的问题的根源是你使用 ObjectFactory 的方式。真的,您不应该在 NancyModule 中使用 ObjectFactory 来“GetInstance”。相反,您应该在需要存储库的 NancyModule 的构造函数中包含 IRepository。然后,Structuremap(已使用您的引导程序连接到 Nancy 框架)将在实例化时简单地将具体存储库注入您的模块。这是一个 NancyModule 的示例:

public class ProductModule : NancyModule {

    private IRepository _repository;

    public ProductModule(IRepository repository) {

        _repository = repository;

        SetupRoutes();
    }

    private void SetupRoutes() {
        Get["/product/{id}"] = p => {
            return _repository.Get<Product>((int)p.id);
        };        
    }
}

在这里,该模块并没有向 IOC 发出请求来获得回购……它已经得到了它。您的引导程序使这成为可能。现在,您可以摆脱 ObjectFactory 的 hacky 配置。

作为一些一般建议,如果您发现自己使用“ObjectFactory”来解析类型,您应该打自己一巴掌并停止输入。相反,您应该像上面显示的那样使用构造函数注入来注入依赖项。

于 2012-10-16T18:43:11.583 回答
1

不确定建议的答案发生了什么,但这是我最终解决此问题的方法。

protected override void ConfigureApplicationContainer(IContainer container)
{
    container.Configure(x =>
    {
        x.ForSingletonOf<IRazorConfiguration>()
            .Use<DefaultRazorConfiguration>();
        x.ForSingletonOf<ISessionContainer>().Use<SessionContainer>();//Duplicate
        x.Scan(scanner=>
        {
            scanner.TheCallingAssembly();
            scanner.AddAllTypesOf<IRepository>();
        });
    });
    ObjectFactory.Configure(x =>
    {
        x.ForSingletonOf<ISessionContainer>().Use<SessionContainer>();//Duplicate
        x.For<IRepository>().Use<Repository>();
    });
    base.ConfigureApplicationContainer(container);
}

这是一个黑客,但这是我设法让它工作的唯一方法。

于 2012-08-27T03:54:35.153 回答