Elmah与Gmail在MVC 3上无法工作

4
我正在使用ELMAH作为我的MVC 3应用程序与Gmail的日志记录工具。我已经查阅了多个参考资料,包括这篇StackOverflow问题,其中提到了多种解决方法。
但是,我仍然无法确定为什么我没有收到来自ELMAH的电子邮件通知。我尝试通过在我的代码中抛出一个NullReferenceException来测试此功能。
我的web.config文件如下所示:
     <configuration>
  <configSections>
    <sectionGroup name="system.web.webPages.razor" type="System.Web.WebPages.Razor.Configuration.RazorWebSectionGroup, System.Web.WebPages.Razor, Version=1.0.0.0, Culture=neutral, PublicKeyToken=31BF3856AD364E35">
      <section name="host" type="System.Web.WebPages.Razor.Configuration.HostSection, System.Web.WebPages.Razor, Version=1.0.0.0, Culture=neutral, PublicKeyToken=31BF3856AD364E35" requirePermission="false" />
      <section name="pages" type="System.Web.WebPages.Razor.Configuration.RazorPagesSection, System.Web.WebPages.Razor, Version=1.0.0.0, Culture=neutral, PublicKeyToken=31BF3856AD364E35" requirePermission="false" />
    </sectionGroup>
    <sectionGroup name="elmah">
      <section name="errorMail" requirePermission="false"  type="Elmah.ErrorMailSectionHandler, Elmah"/>
      <section name="security" requirePermission="false" type="Elmah.SecuritySectionHandler, Elmah"/>
      <section name="errorLog" requirePermission="false" type="Elmah.ErrorLogSectionHandler, Elmah"/>
      <section name="errorFilter" requirePermission="false" type="Elmah.ErrorFilterSectionHandler, Elmah"/>
    </sectionGroup>
  </configSections>

  <system.web.webPages.razor>
    <host factoryType="System.Web.Mvc.MvcWebRazorHostFactory, System.Web.Mvc, Version=3.0.0.0, Culture=neutral, PublicKeyToken=31BF3856AD364E35" />
    <pages pageBaseType="System.Web.Mvc.WebViewPage">
      <namespaces>
        <add namespace="System.Web.Mvc" />
        <add namespace="System.Web.Mvc.Ajax" />
        <add namespace="System.Web.Mvc.Html" />
        <add namespace="System.Web.Routing" />
      </namespaces>
    </pages>
  </system.web.webPages.razor>

  <appSettings>
    <add key="webpages:Enabled" value="false" />
  </appSettings>
  <system.web>
    <httpHandlers>
      <add path="*" verb="*" type="System.Web.HttpNotFoundHandler"/>
      <add verb="POST,GET,HEAD" path="elmah.axd" type="Elmah.ErrorLogPageFactory, Elmah"/>
    </httpHandlers>
    <httpModules>
      <add name="ErrorMail" type="Elmah.ErrorMailModule, Elmah"/>
      <add name="ErrorLog" type="Elmah.ErrorLogModule, Elmah"/>
      <add name="ErrorFilter" type="Elmah.ErrorFilterModule, Elmah"/>
    </httpModules>

    <!--
        Enabling request validation in view pages would cause validation to occur
        after the input has already been processed by the controller. By default
        MVC performs request validation before a controller processes the input.
        To change this behavior apply the ValidateInputAttribute to a
        controller or action.
    -->
     <pages
        validateRequest="false"
        pageParserFilterType="System.Web.Mvc.ViewTypeParserFilter, System.Web.Mvc, Version=3.0.0.0, Culture=neutral, PublicKeyToken=31BF3856AD364E35"
        pageBaseType="System.Web.Mvc.ViewPage, System.Web.Mvc, Version=3.0.0.0, Culture=neutral, PublicKeyToken=31BF3856AD364E35"
        userControlBaseType="System.Web.Mvc.ViewUserControl, System.Web.Mvc, Version=3.0.0.0, Culture=neutral, PublicKeyToken=31BF3856AD364E35">
      <controls>
        <add assembly="System.Web.Mvc, Version=3.0.0.0, Culture=neutral, PublicKeyToken=31BF3856AD364E35" namespace="System.Web.Mvc" tagPrefix="mvc" />
      </controls>
      </pages>
      </system.web>
      <system.net>
    <mailSettings>
      <smtp deliveryMethod="Network">
        <network host="smtp.gmail.com" port="587" userName="username@gmail.com" password="myPassword"/>
      </smtp>
    </mailSettings>
    </system.net>
    <elmah>
    <errorMail   from="fromAddress@gmail.com" to="toAddress@gmail.com" subject="Error" async="true" smtpPort="587"       useSsl="true"/>
    </elmah>
    <system.webServer>
    <validation validateIntegratedModeConfiguration="false" />

      <handlers>
      <remove name="BlockViewHandler"/>
      <add name="BlockViewHandler" path="*" verb="*" preCondition="integratedMode"    type="System.Web.HttpNotFoundHandler" />
      <add name="Elmah" verb="POST,GET,HEAD" path="elmah.axd"      type="Elmah.ErrorLogPageFactory, Elmah"/>
    </handlers>

    <modules runAllManagedModulesForAllRequests="true">
      <add name="ErrorLog" type="Elmah.ErrorLogModule, Elmah"/>
      <add name="ErrorMail" type="Elmah.ErrorMailModule, Elmah" />
      <add name="ErrorFilter" type="Elmah.ErrorFilterModule, Elmah" />
    </modules>
    </system.webServer>
    </configuration>

有什么想法,为什么这个可能不起作用?

1
愚蠢的问题,但是必须问 - 你检查过Gmail的垃圾邮件过滤器吗?我经常忘记查看那里,但有时它可能会很严格。 - Ken Pespisa
没有所谓的愚蠢问题!话虽如此,我已经检查过了,但是没有运气=( 我的想法用尽了!感谢您的评论! - TheJediCowboy
1个回答

8
编辑: 看其他ELMAH配置,这可能并不一定正确,但您仍然可以尝试。此外,我知道system.net邮件设置上的enableSSL属性是.NET 4.0中的新功能 - 您也可能想在该部分中添加enableSSL=true ,因为GMail确实使用SSL进行连接。
看起来当您将自己的ELMAH设置与其他ELMAH配置进行比较时,在电子邮件方面遗漏了主机配置属性和其他一些设置。我认为ELMAH不会查看system.net邮件设置,而是使用其自己的errorMail标记。
<elmah>
    <errorMail 
      from="fromAddress@gmail.com"
       to="toAddress@gmail.com"
       subject="Error"
       async="true"
       smtpPort="587"
       useSsl="true"/>
    </elmah>

应该将其更改为这样:
<elmah>
    <errorMail 
      from="fromAddress@gmail.com"
       to="toAddress@gmail.com"
       subject="Error"
       async="true"
       smtpPort="587"
       useSsl="true"
       host="smtp.gmail.com"
       userName="username@gmail.com"
       password="myPassword"/>
    </elmah>

2
在<errorMail>中,将smtpPort属性设置为“0”。这样做将导致ELMAH使用根据<system.net>设置定义的端口。 - AhsenBaig
主机属性应该是smtpServer吗? - Scott Coates
我不确定这里的哪一部分起了作用,但我曾经为了让elmah通过SES发送电子邮件而苦苦挣扎了整整一天,使用您的设置对我很有帮助!谢谢! - Avalanchis
Elmah的邮件设置对我很有效。我有一个Web应用程序和一个Windows服务,我都使用Elmah。它们都没有转发电子邮件。我在两个节点的elmah配置中添加了邮件设置,它们都开始工作了。 - Brandon Lewis

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接