从Elmah发送电子邮件?


87

是否有人使用Elmah通过电子邮件发送例外?我已经通过SQL Server设置了Elmah日志记录,并且可以通过Elmah.axd页面查看错误页面,但是我无法使电子邮件组件正常工作。这里的想法是获取电子邮件通知,以便我们可以更快地对异常做出反应。这是我的web.config(省略不必要的部分),所有敏感数据都替换为* * *。即使我指定要连接的服务器,SMTP服务是否也需要在本地计算机上运行?

<?xml version="1.0"?>
<configuration>
    <configSections>
        <sectionGroup name="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>
    </configSections>
    <appSettings/>
    <connectionStrings>
        <add name="elmah-sql" connectionString="Data Source=***;Initial Catalog=***;Persist Security Info=True;User ID=***;Password=***" />
    </connectionStrings>

    <elmah>
        <errorLog type="Elmah.SqlErrorLog, Elmah" connectionStringName="elmah-sql"   >
        </errorLog>
        <errorMail from="test@test.com"
           to="test@test.com"
           subject="Application Exception"
           async="false"
           smtpPort="25"
           smtpServer="***"
           userName="***"
           password="***">
        </errorMail>
    </elmah>

    <system.web>        
        <customErrors mode="RemoteOnly" defaultRedirect="CustomError.aspx">
            <error statusCode="403" redirect="NotAuthorized.aspx" />
            <!--<error statusCode="404" redirect="FileNotFound.htm" />-->
        </customErrors>
        <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="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="ErrorLog" type="Elmah.ErrorLogModule, Elmah"/>
        </httpModules>
    </system.web>

</configuration>

Answers:


79

您需要ErrorMail httpModule。

在<httpModules>部分中添加此行

<add name="ErrorMail" type="Elmah.ErrorMailModule, Elmah" />

如果您使用的是远程SMTP服务器(看起来像是在使用),则服务器上不需要SMTP。


1
有没有一种方法可以配置日常作业以发送合并错误?
Chaitanya Gadkari

65

是的,如果您不使用远程SMTP服务器,则必须在本地配置SMTP服务器。您还可以在web.config中为elmah配置电子邮件,如下所示:

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

<elmah> 
     <errorMail from="from Mail Address" to="to mail address" 
                async="true"  smtpPort="0" useSsl="true" /> 
</elmah>

<system.net> 
    <mailSettings> 
      <smtp deliveryMethod ="Network"> 
        <network host="smtp.gmail.com" port="587" userName="yourgmailEmailAddress"   password="yourGmailEmailPassword" /> 
      </smtp> 
    </mailSettings> 
</system.net>

4
这很棒。我没有意识到ELMAH可以加入标准的mailSettings部分。smtpPort =“ 0”属性有点奇怪。
本·米尔斯

1
似乎不需要smtpPort =“ 0”,因为它使用了system.net下指定的端口。与开发服务器中运行,而我必须设置useSsl =“假”,否则它会导致服务器崩溃(可能是因为我没有建立SSL)
的Răzvan弗拉菲乌斯熊猫

我发现元素的顺序很重要。在elmah FAILED失败后指定system.net。ELMAH系统的行为就像未定义邮件服务器一样。首先把system.net变成可以工作。
Mark Meuer

如果我使用上述设置,则任何访问web.config文件的人都会知道我的电子邮件密码吗?
坚不可摧的

5

我本人在此配置中使用过Elmah,因此必须在本地使用SMTP设置服务器。这是在本地IIS服务器上的直接安装。这应该可以解决问题。

上面的要点是,如果不使用远程SMTP服务器,则需要使用errorMail模块,但为了澄清起见,您需要在本地使用SMTP。

By using our site, you acknowledge that you have read and understand our Cookie Policy and Privacy Policy.
Licensed under cc by-sa 3.0 with attribution required.