Pergunta

Novo no Castle/Windsor, por favor, tenha paciência comigo.

Atualmente estou usando a estrutura System.Web.MVC.Extensibility E em seu código de inicialização, ele registrou HttpContextBase como o seguinte:

container.Register(Component.For<HttpContextBase>().LifeStyle.Transient.UsingFactoryMethod(() => new HttpContextWrapper(HttpContext.Current)));

O que eu queria fazer é mudar o comportamento e mudar o estilo de vida da HttpContextBase para ser perwebrequest.

Então, eu mudei o código para o seguinte:

container.Register(Component.For<HttpContextBase>().LifeStyle.PerWebRequest.UsingFactoryMethod(() => new HttpContextWrapper(HttpContext.Current)));

No entanto, quando faço isso, recebi o seguinte erro:

 System.Configuration.ConfigurationErrorsException: Looks like you forgot to 
 register the http module Castle.MicroKernel.Lifestyle.PerWebRequestLifestyleModule
 Add '<add name="PerRequestLifestyle" 
 type="Castle.MicroKernel.Lifestyle.PerWebRequestLifestyleModule, Castle.MicroKernel" 
 />' to the <httpModules> section on your web.config

que eu fiz sob <system.web> e <system.webServer>, no entanto, ainda estou recebendo o mesmo erro. Alguma dica?

Desde já, obrigado.

Atualizar

Bloco de código adicionado por solicitação

Na estrutura System.Web.MVC.Extensibility, existe uma classe chamada ExtendedMVCApplication que herda a partir de httpplication e, no método Application_Start, chama bootstrapper.execute (). Esta implementação deste método é o seguinte:

public void Execute()
    {
        bool shouldSkip = false;

        foreach (IBootstrapperTask task in ServiceLocator.GetAllInstances<IBootstrapperTask>().OrderBy(task => task.Order))
        {
            if (shouldSkip)
            {
                shouldSkip = false;
                continue;
            }

            TaskContinuation continuation = task.Execute(ServiceLocator);

            if (continuation == TaskContinuation.Break)
            {
                break;
            }

            shouldSkip = continuation == TaskContinuation.Skip;
        }
    }

Como você pode ver, ele atravessa uma lista de iBootstrapperTask e tenta executá -los. Acontece que tenho uma tarefa que registre as rotas no meu aplicativo MVC:

public class RegisterRoutes : RegisterRoutesBase
{
    private HttpContextBase contextBase;

    protected override TaskContinuation ExecuteCore(IServiceLocator serviceLocator)
    {
        contextBase = serviceLocator.GetInstance<HttpContextBase>();
        return base.ExecuteCore(serviceLocator);
    }

    protected override void Register(RouteCollection routes)
    {
        routes.IgnoreRoute("{resource}.axd/{*pathInfo}");
        routes.IgnoreRoute("{*favicon}", new { favicon = @"(.*/)?favicon.ico(/.*)?" });
        routes.IgnoreRoute("{*robotstxt}", new { robotstxt = @"(.*/)?robots.txt(/.*)?" });

        XmlRouting.SetAppRoutes(routes, contextBase.Server.MapPath("~/Configuration/Routes.xml"));
    }
}

Você pode ver que eu preciso obter (resolver) um objeto HTTPContextBase, de modo que eu possa obter o caminho do servidor de um arquivo XML.

Foi útil?

Solução

Até o momento em que este artigo foi escrito, o estilo de vida de Perwebrequest não suporta a resolução no application_start ().

Veja a descrição e discussão da edição:

Soluções alternativas para este caso em particular:

  1. Registro RegisterRoutes Como instância, passando explicitamente o contexto atual como parâmetro construtor, por exemplo:

    container.Register(Component.For<IBootstrapperTask>()
                                .Instance(new RegisterRoutes(Context)));
    
  2. Usar HostingEnvironment.MapPath ao invés de contextBase.Server.MapPath. Quer torná -lo mockable? Use -o através de uma interface simples, por exemplo:

    interface IServerMapPath {
        string MapPath(string virtualPath);
    }
    
    class ServerMapPath: IServerMapPath {
        public string MapPath(string virtualPath) {
            return HostingEnvironment.MapPath(virtualPath);
        }
    }
    
    container.AddComponent<IServerMapPath, ServerMapPath>();
    

Então injete IServerMapPath dentro de voce RegisterRoutes.

Licenciado em: CC-BY-SA com atribuição
Não afiliado a StackOverflow
scroll top