ELMAH.axd доступен для просмотра, но никогда не будет регистрировать мои ошибки?

У меня все это настроено, и я могу перейти к /elmah.axd, но я вызывал все эти ошибки, и он не регистрирует ни одну из них, он просто говорит, что ошибки не зарегистрированы ... что, черт возьми, я сделал неправильный?

Вот что я добавил в свой web.config:

<configSections>
  <sectionGroup name="elmah">     
        <section name="security" requirePermission="false" type="Elmah.SecuritySectionHandler, Elmah" />     
        <section name="errorLog" requirePermission="false" type="Elmah.ErrorLogSectionHandler, Elmah" />     
        <section name="errorMail" requirePermission="false" type="Elmah.ErrorMailSectionHandler, Elmah" />     
  </sectionGroup>
</configSections>

<httpHandlers>
  <add verb="POST,GET,HEAD" path="elmah.axd" type="Elmah.ErrorLogPageFactory, Elmah" />
</httpHandlers>

<httpModules>
  <add name="ErrorLog" type="Elmah.ErrorLogModule, Elmah" />  
</httpModules>

<elmah>
  <errorLog type="Elmah.XmlFileErrorLog, Elmah" logPath="~/App_Data" />
  <security allowRemoteAccess="yes" />
</elmah>

ТАКЖЕ: это уже было в начале моего RegisterRoutes ()

routes.IgnoreRoute("{resource}.axd/{*pathInfo}");

Я читал, что с ASP.NET MVC 1.0 это больше не имеет значения, предположительно (на веб-сайте ELMAH ...)


person Ryan    schedule 06.01.2010    source источник


Ответы (2)


Конфиг вроде в порядке; я предполагаю, что у вашего пользователя веб-приложения IIS нет разрешения на запись в App_Data. Если вы заблокировали разрешения, пользователь приложения будет иметь там права на чтение, но не на запись.

Вы можете открыть разрешения или войти в другой каталог за пределами веб-пути (что немного безопаснее IMO) и убедиться, что там установлены разрешения на чтение / запись для пользователя.

person 48klocs    schedule 06.01.2010

Рецепт решения

Я установил с nuget elmah и elmah on XML log, не получил ожидаемой функциональности, хотя я мог получить доступ к http://localhost/elmah.axd, но без регистрации ошибок.

Я дал разрешение на запись учетной записи IIS_IUSERS в папке APP_DATA, и она начала работать с ошибками HTTP 404 и ошибками, которые находятся вне инфраструктуры MVC. Но он не регистрировал исключения внутри mvc. Решением было установить пакет elmah.mvc с nuget, и он начал собирать все исключения.

Если с вашей конфигурацией все в порядке, просто установите пакет elmah.mvc из nuget, и он должен начать хранить журналы также внутри mvc, а не только по HTTP 404.

person visar_uruqi    schedule 03.01.2013