17

我正在尝试将 elmah 用于我的 MVC 应用程序,并且我已按照 wiki 上的步骤操作:http ://code.google.com/p/elmah/wiki/MVC ,但即便如此尝试访问 myapp/elmah .axd 页面:

404 - 找不到文件或目录。

任何人都可以帮助我吗?

OBS:我的 IIS 版本是 7.5


如果有帮助,我将发布我的 web.config 的相关部分:

<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" />
  <section name="errorFilter" requirePermission="false" type="Elmah.ErrorFilterSectionHandler, Elmah" />
</sectionGroup>
...
</connectionStrings>
<elmah>
  <errorLog type="Elmah.XmlFileErrorLog, Elmah" logPath="~/App_Data" />
</elmah>
<system.web>
...
<httpHandlers>
  <remove verb="*" path="*.asmx" />
  <add verb="*" path="*.asmx" validate="false" type="System.Web.Script.Services.ScriptHandlerFactory, System.Web.Extensions, Version=3.5.0.0, Culture=neutral, PublicKeyToken=31BF3856AD364E35" />
  <add verb="*" path="*_AppService.axd" validate="false" type="System.Web.Script.Services.ScriptHandlerFactory, System.Web.Extensions, Version=3.5.0.0, Culture=neutral, PublicKeyToken=31BF3856AD364E35" />
  <add verb="GET,HEAD" path="ScriptResource.axd" type="System.Web.Handlers.ScriptResourceHandler, System.Web.Extensions, Version=3.5.0.0, Culture=neutral, PublicKeyToken=31BF3856AD364E35" validate="false" />
  <add verb="*" path="*.mvc" validate="false" type="System.Web.Mvc.MvcHttpHandler, System.Web.Mvc, Version=1.0.0.0, Culture=neutral, PublicKeyToken=31BF3856AD364E35" />
  <add verb="POST,GET,HEAD" path="elmah.axd" type="Elmah.ErrorLogPageFactory, Elmah" />
</httpHandlers>
<httpModules>
  <add name="ScriptModule" type="System.Web.Handlers.ScriptModule, System.Web.Extensions, Version=3.5.0.0, Culture=neutral, PublicKeyToken=31BF3856AD364E35" />
  <add name="UrlRoutingModule" type="System.Web.Routing.UrlRoutingModule, System.Web.Routing, Version=3.5.0.0, Culture=neutral, PublicKeyToken=31BF3856AD364E35" />
  <add name="ErrorLog" type="Elmah.ErrorLogModule, Elmah" />
  <add name="ErrorMail" type="Elmah.ErrorMailModule, Elmah" />            
  <add name="ErrorFilter" type="Elmah.ErrorFilterModule, Elmah" />
</httpModules>

在我的 Global.asax.cs 上

public static void RegisterRoutes(RouteCollection routes)
{   
  routes.IgnoreRoute("{resource}.axd/{*pathInfo}");
...
4

4 回答 4

14

对于 IIS 7+,您还需要填充 system.webServer 配置部分。看到这个问题

于 2010-01-22T15:35:09.923 回答
6

是在 MVC 中使用 ELMAH 的一种很好的方法,它不使用axd控制器和自定义ElmahActionResult.

于 2011-03-05T17:41:32.377 回答
1

尝试将此添加到您的 web.config 文件中

<system.webServer>

    <handlers>
        <remove name="ErrorLog" />
        <remove name="ErrorMail" />
        <remove name="ErrorFilter" />
        <add name="ErrorLog" type="Elmah.ErrorLogModule, Elmah" />
        <add name="ErrorMail" type="Elmah.ErrorMailModule, Elmah" />            
        <add name="ErrorFilter" type="Elmah.ErrorFilterModule, Elmah" />     
    </handlers>       
</system.webServer>
于 2010-01-22T15:34:14.903 回答
1

为了帮助其他人体验 @zanona 在 2010 年遇到的问题(请参阅上面对 @hunter 回复的评论),以下更改今天为我修复了完全相同的“HTTP 错误 500.19 - 内部服务器错误”。请注意@hunter 回复中配置标签的位置是导致@zanona 错误的原因。@hunter 提到的那些标签属于模块标题,而不是处理程序!

<modules>
  <remove name="ErrorLog" />
  <remove name="ErrorMail" />
  <remove name="ErrorFilter" />
  <add name="ErrorLog" type="Elmah.ErrorLogModule, Elmah" />
  <add name="ErrorMail" type="Elmah.ErrorMailModule, Elmah" />            
  <add name="ErrorFilter" type="Elmah.ErrorFilterModule, Elmah" /> 
 </modules>       

上述修复为我消除了 @zanona 首次报告的相同“配置错误 - 缺少必需的属性‘路径’”问题。该错误是由于处理程序组中的标签的结构方式导致的,而他重新排列的标签显然没有路径属性(因为它们不属于那里,而是属于模块标签下! )。现在,处理程序部分中的标签应如下所示:

<handlers>

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

</handlers>

请注意那里存在路径属性?啊!

感谢@hunter 和@zanona,因为他们确实让我走上了解决问题所需的道路。

(注意:我已尝试编辑上面@hunter 的原始帖子以进行更正,但同行评审速度很慢,我想我会在此处保留此回复以帮助同时面临相同挑战的任何人。当该编辑是接受,我们可以删除这篇文章。)

于 2017-05-18T20:57:59.990 回答