SMTP Appender - log4net问题

时间:2011-06-23 14:52:48

标签: xml logging configuration web-config log4net

我在使用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 个答案:

答案 0 :(得分: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(默认设置)的服务器。“

我不确定,但我认为这意味着任何基于.NET而不是1.1构建的应用程序,身份验证将无效。您使用的是1.1或更高版本吗?

答案 1 :(得分:0)

将此添加到配置部分的末尾

    <appSettings>
         <add key="log4net.Internal.Debug" value="true"/>
    </appSettings>

您将能够追踪错误