В новинку для Замка/Виндзора, терпите меня.
Я в настоящее время использую Систему платформы. Сеть. Mvc. Расширяемость и в ее коде запуска, это зарегистрировало HttpContextBase как следующее:
container.Register(Component.For().LifeStyle.Transient.UsingFactoryMethod(() => new HttpContextWrapper(HttpContext.Current)));
То, что я хотел сделать, должно изменить поведение и изменить образ жизни httpContextBase, чтобы быть PerWebRequest.
таким образом, я имею, изменяют код на следующее:
container.Register(Component.For().LifeStyle.PerWebRequest.UsingFactoryMethod(() => new HttpContextWrapper(HttpContext.Current)));
Однако, когда я делаю это, я получил следующую ошибку:
System.Configuration.ConfigurationErrorsException: Looks like you forgot to
register the http module Castle.MicroKernel.Lifestyle.PerWebRequestLifestyleModule
Add ' ' to the section on your web.config
под которым я сделал
и
, однако, я все еще получаю ту же ошибку. Какие-либо подсказки?
Заранее спасибо.
Обновление
добавленный блок кода на запрос
В system.web.mvc.extensibility платформе существует класс, названный extendedMvcApplication, которые наследовались HttpApplication, и в методе Application_start, это называет BootStrapper. Выполнитесь (). Эта реализация этого метода следующая:
public void Execute()
{
bool shouldSkip = false;
foreach (IBootstrapperTask task in ServiceLocator.GetAllInstances().OrderBy(task => task.Order))
{
if (shouldSkip)
{
shouldSkip = false;
continue;
}
TaskContinuation continuation = task.Execute(ServiceLocator);
if (continuation == TaskContinuation.Break)
{
break;
}
shouldSkip = continuation == TaskContinuation.Skip;
}
}
Как Вы видите, это циклично выполняется через список IBootStrapperTask и пытается выполнить их. Это так происходит, что у меня есть одна задача, которые регистрируют маршруты в моем mvc приложении:
public class RegisterRoutes : RegisterRoutesBase
{
private HttpContextBase contextBase;
protected override TaskContinuation ExecuteCore(IServiceLocator serviceLocator)
{
contextBase = serviceLocator.GetInstance();
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"));
}
}
Вы видите, что мне нужно к getInstance (твердость), httpcontextbase возражает таким образом, что я могу получить путь сервера XML-файла.
На момент написания этой статьи стиль жизни PerWebRequest не поддерживает разрешение в Application_Start ().
См. Описание проблемы и обсуждение:
Обходные пути для этого конкретного случая:
Зарегистрируйте RegisterRoutes
в качестве экземпляра, явно передав ему текущий контекст в качестве параметра конструктора, например:
container.Register (Component.For ()
.Instance (new RegisterRoutes (Context)));
Используйте HostingEnvironment.MapPath
вместо ] contextBase.Server.MapPath
. Хотите сделать это издевательским? Используйте его через простой интерфейс, например:
interface IServerMapPath {
string MapPath (string virtualPath);
}
class ServerMapPath: IServerMapPath {{{ 1}} общедоступная строка MapPath (string virtualPath) {
return HostingEnvironment.MapPath (virtualPath);
}
}
container.AddComponent < IServerMapPath, ServerMapPath> ();
Затем введите IServerMapPath
в свой RegisterRoutes
.
Мэйби попытается добавить его в раздел Модули, как здесь: IIS7 & Castle.MicroKernel.Lifestyle.PerWebRequestLifestyleModule регистрации проблем