结构图nancy bootstrapper

时间:2012-08-26 18:58:00

标签: structuremap nancy

我正在尝试使用structuremap bootstrapper启动带nancyfx https://github.com/NancyFx/Nancy.Bootstrappers.StructureMap

这是我的设置:

        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 

2 个答案:

答案 0 :(得分: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);
        };        
    }
}

在这里,模块没有呼叫国际奥委会来获得回购......它已经得到了它。你的引导程序使这成为可能。现在,您可以摆脱ObjectFactory的hacky配置。

作为一些一般性建议,如果您发现自己使用“ObjectFactory”来解析类型,那么您应该自己动手并停止输入。相反,您应该使用构造函数注入注入依赖项,如上所示。

答案 1 :(得分: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);
}

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