9

Log4Net 配置示例网页上,它显示了有关如何设置 SmtpAppender 的示例。

因此,我将以下设置添加到我的 app.config 文件中,并在记录警告或更高级别时成功发送电子邮件(这很好)。

<appender name="EmailAppender" type="log4net.Appender.SmtpAppender">
  <to value="me@mycompany.com" />
  <from value="me@mycompany.com" />
  <subject value="test logging message" />
  <smtpHost value="smtpserver.mycompany.com" />
  <lossy value="true" />
  <evaluator type="log4net.Core.LevelEvaluator">
    <threshold value="WARN"/>
  </evaluator>
  <layout type="log4net.Layout.PatternLayout">
    <conversionPattern value="%newline%date [%thread] %-5level %logger [%property{NDC}] - %message%newline%newline%newline" />
  </layout>
</appender>

但是From值是用我的电子邮件地址硬编码的。

我的应用程序是一个 WinForms 应用程序,它将被部署到用户的 PC 上,因此知道哪个用户遇到了警告/错误会非常方便。

是否可以设置 Log4Net SmtpAppender 以便 From 值使用当前用户的电子邮件地址?

感谢您的帮助。

4

3 回答 3

6

有两个问题

1) 确定用户的电子邮件地址。如果它们是域的一部分,那么您可以尝试

  System.DirectoryServices.AccountManagement.UserPrincipal.Current.EmailAddress

2)。在 Log4net 中使用它。应该可以使用属性来做到这一点,例如

如果你改变你的 app.config 从

<from value="me@mycompany.com" />

<from type="log4net.Util.PatternString" value="%property{From}" />

并在您的程序中添加一行来设置属性,例如

log4net.GlobalContext.Properties["From"] = 
   System.DirectoryServices.AccountManagement.UserPrincipal.Current.EmailAddress ;

您可能还需要将缓冲区大小设置为 1。

为了安全起见,最好将用户名也包含在错误消息中。

这种方法的缺点是,如果发件人地址丢失或不正确,电子邮件可能会丢失。

于 2013-01-10T20:05:09.087 回答
5

这是如何在运行时设置 SMTP 附加程序的简单示例。您可以设置 Smtp appender 的任何属性。将 FindAppenderByName 中的 appender name 参数设置为与配置中的 appender name 相同的名称。

    public static IAppender FindAppenderByName(string name)
    {
        ILoggerRepository rootRep = LogManager.GetRepository();
        foreach (IAppender iApp in rootRep.GetAppenders())
        {
            if (string.Compare(name, iApp.Name, true) == 0)
            {
                return iApp;
            }
        }
        return null;
    }

    private void SetupSmtpAppender()
    {
        IAppender appender = FindAppenderByName("Global.SmtpAppender");
        SmtpAppender smtpAppender = (SmtpAppender)appender;
        smtpAppender.From = "me@domain.com";
        smtpAppender.Subject = "My subject";
        smtpAppender.SmtpHost = "smtp@mydomain.com";
... setup more properties
    }

这是来自 log4net.config 的片段:

<appender name="Global.SmtpAppender" type="log4net.Appender.SMTPAppender">
  <threshold value="WARN" />
</appender>
于 2013-10-01T14:55:39.200 回答
4

经过大量的谷歌搜索,我终于找到了这篇很棒的CodeProject 文章,它展示了如何使用 AppenderSkeleton 抽象类作为基础来创建一个新的自定义 Smtp Appender。

它很简单,并且可以更改,以便在运行时动态设置 From 属性。它还展示了如何为主题属性传递模式,以便您的电子邮件主题可以包含记录的事件级别和其他信息。

例如

<subject type="HHR.log4net.Layout.PatternLayout, HHR.log4net">
   <conversionPattern value="%date %level %exceptType at [%logger] on %property{log4net:HostName} by %username" />
</subject>
于 2013-01-11T08:50:39.303 回答