如何在 ELMAH 中连接自定义电子邮件提供商?

How can I hook up custom email provider in ELMAH?

我已经在 google 组的 elmah 组中问过这个问题,但我仍然很困惑,所以我想我应该把它扔到一个更大的池中。这是原始注释,其中包含我目前的代码。


我在我的 MVC 5 应用程序上设置了 ELMAH,我想使用自定义电子邮件服务发送电子邮件,而不是使用默认设置的 smtp 发送。 (这是一种组织偏好。)我一直在研究它,但不知道该怎么做。我的服务调用工作正常,但我无法将其连接起来以便在出现异常时运行。如有任何帮助,我们将不胜感激。

我的设置如下:

Web.config(删除了与 elmah 无关的行):

<?xml version="1.0" encoding="utf-8"?>
<!--
  For more information on how to configure your ASP.NET application, please visit
  http://go.microsoft.com/fwlink/?LinkId=301880
  -->
<configuration>
  <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" />
      <section name="errorFilter" requirePermission="false" type="Elmah.ErrorFilterSectionHandler, Elmah" />
    </sectionGroup>
  </configSections><appSettings>
    ...
    <add key="elmah.mvc.disableHandler" value="false" />
    <add key="elmah.mvc.disableHandleErrorFilter" value="false" />
    <add key="elmah.mvc.requiresAuthentication" value="false" />
    <add key="elmah.mvc.IgnoreDefaultRoute" value="false" />
    <add key="elmah.mvc.allowedRoles" value="*" />
    <add key="elmah.mvc.allowedUsers" value="*" />
    <add key="elmah.mvc.route" value="elmah" />
</appSettings>
  <connectionStrings>
    <add name="BFRDPDB" providerName="System.Data.SqlClient" connectionString="blahblah;" />
  </connectionStrings>
  <system.web>
    <compilation debug="true" targetFramework="4.5.1" />
    <customErrors mode="Off" defaultRedirect="~/Home/Error">
      <error statusCode="404" redirect="~/Home/Error" />
    </customErrors>
    <httpModules>
      <add name="ErrorLog" type="Elmah.ErrorLogModule, Elmah" />
      <add name="ErrorMail" type="BFRDP.Infrastructure.ErrorMailModule" />
      <add name="ErrorFilter" type="Elmah.ErrorFilterModule, Elmah" />
    </httpModules>
  </system.web>
  <system.webServer>
    <validation validateIntegratedModeConfiguration="false" />
    <modules>
      <add name="ErrorLog" type="Elmah.ErrorLogModule, Elmah" preCondition="managedHandler" />
      <add name="ErrorMail" type="BFRDP.Infrastructure.ErrorMailModule" preCondition="managedHandler" />
      <add name="ErrorFilter" type="Elmah.ErrorFilterModule, Elmah" preCondition="managedHandler" />
    </modules>
  </system.webServer>
  <elmah>
    <security allowRemoteAccess="false" />
    <errorLog type="Elmah.SqlErrorLog, Elmah"
              connectionStringName="BFRDPDB"
              applicationName="FarmAnswers.org" /> 
  </elmah>
  <location path="elmah">
    <system.web>
      <httpHandlers>
        <add verb="POST,GET,HEAD"
             path="elmah.axd"
             type="Elmah.ErrorLogPageFactory, Elmah" />
      </httpHandlers>
      <authorization>
        <allow roles="SuperAdmin" />
        <deny users="*" />
      </authorization>
    </system.web>
    <system.webServer>
      <handlers>
        <add name="ELMAH"
             verb="POST,GET,HEAD"
             path="elmah"
             type="Elmah.ErrorLogPageFactory, Elmah"
             preCondition="integratedMode" />
      </handlers>
    </system.webServer>
  </location>
</configuration>

我的 ErrorMailModule.cs 文件如下所示:

using System;
using System.Collections.Generic;
using System.Linq;
using System.Web;
using System.Net.Mail;

namespace BFRDP.Infrastructure
{/// <summary>
    /// Summary description for ErrorMailModule
    /// </summary>
    public class ErrorMailModule : Elmah.ErrorMailModule
    {
        public ErrorMailModule()
        {
        }



        protected override void SendMail(MailMessage mail)
        {
            if (mail == null)
                throw new ArgumentNullException("mail");
            // Code to send email here through internal provider
        }

    }
}

我的错误确实记录在数据库中,但从未到达发送电子邮件的代码。

我做错了什么?

在我的 web.config 部分添加了 errorMail 设置,应用程序能够访问我的自定义模块:

  <elmah>
    <security allowRemoteAccess="false" />
    <errorLog type="Elmah.SqlErrorLog, Elmah" connectionStringName="BFRDPDB" applicationName="FarmAnswers.org" />
    <errorMail
    from="elmah@example.com"
    to="admin@example.com"
    subject="..."
    priority="Low"
    async="true"
    smtpPort="25"
    smtpServer="smtp.example.com"
    useSsl="true"
    userName="johndoe"
    password="secret"
    noYsod="true" />
  </elmah>