SMTP Appender - log4net 问题

3

我有一个SMTP appender无法正常工作的问题:

我有以下配置文件设置:

<log4net>
<appender name="LogFileAppender" type="log4net.Appender.FileAppender">
  <param name="File" value="folder\\filelog.log"/>
  <layout type="log4net.Layout.PatternLayout">
    <param name="ConversionPattern" value="%d [%t] %-5p %c %m%n"/>
  </layout>
</appender>
<appender name="SmtpAppender" type="log4net.Appender.SmtpAppender">
  <to value="xxx@mail.com" />
  <from value="xxx@mail.com" />
  <subject value="Error in site" />
  <smtpHost value="111.111.111.111" />
  <authentication value="1"/>
  <username Value="user@name.co.uk" />
  <password value="password" />
  <port value="25" />
  <bufferSize value="1" />
  <lossy value="false" />
  <threshold value="ALL"/>
  <evaluator type="log4net.Core.LevelEvaluator">
    <threshold value="ALL"/>
  </evaluator>
  <layout type="log4net.Layout.PatternLayout">
    <conversionPattern value="%newline%date [%thread] %-5level %logger [%property] - %message%newline%newline%newline" />
  </layout>
</appender>

<logger name="File">
  <level value="All" />
  <appender-ref ref="LogFileAppender" />
</logger>

<logger name="EmailAppender">
  <level value="ALL" />
  <appender-ref ref="SmtpAppender" />
</logger>

我想记录一个错误以查看是否收到邮件:

            log4net.Config.XmlConfigurator.Configure();
        ILog logger = LogManager.GetLogger("EmailAppender");
        logger.Error("uyyy: " + DateTime.Now.ToLongDateString());

电子邮件没有到达。 如果我切换到“文件”,它就能正确记录日志。

我知道我添加的凭据是正确的,因为我在系统的其他地方使用它们时没有问题。

编辑:我尝试使用上面“空白”的配置运行,并且在继续之前运行logger.Error行需要一段时间。使用我的真实详细信息,它可以立即运行,无需延迟。

2个回答

1

来自 - http://logging.apache.org/log4net/release/sdk/log4net.Appender.SmtpAppender.html

"注意——认证和设置服务器端口仅适用于 MS .NET 1.1 运行时。为了使这些功能可用,您需要确保使用的 log4net 程序集版本是针对 MS .NET 1.1 框架构建的,并且您正在运行应用程序在 MS .NET 1.1 运行时上。在所有其他平台上,只支持向侦听端口25(默认值)的服务器发送未经身份验证的消息。"

我不确定,但我认为这意味着在1.1之后构建的任何应用程序,身份验证将不起作用。您是否使用的是1.1或更高版本?


我在dotNet 4.5上进行了测试,它的表现非常出色。即使该注释仍然存在于网站上,但似乎已经过时了。有人可以确认吗? - Askolein

0
将此内容添加到配置部分的末尾。
    <appSettings>
         <add key="log4net.Internal.Debug" value="true"/>
    </appSettings>

您将能够追踪错误


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