我在使用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行需要一段时间。凭借我的真实细节,它可以立即运行,毫不拖延。
答案 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>
您将能够追踪错误