castelo perrequestlifestyle não reconhece
-
28-09-2019 - |
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.
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:
- http://support.castleproject.org/projects/ioc/issues/view/ioc-issue-166
- http://groups.google.com/group/castle-project-users/browse_thread/thread/d44d96f4b548611e
Soluções alternativas para este caso em particular:
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)));
Usar
HostingEnvironment.MapPath
ao invés decontextBase.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
.
Outras dicas
Maby tenta adicioná -lo na seção de módulos, como aqui:Iis7 & castle.microkernel.lifestyle.perwebrequestlifestylemodule Problemas de registro