2013-04-04 16 views
6

Próbuję wysłać do mnie wiadomość e-mail w formacie HTML.Log4net sformatowany w formacie html SmtpAppender

<appender name="SmtpAppender" type="log4net.Appender.SmtpAppender"> 

    <to value="[email protected]"/> 
    <from value="[email protected]"/> 
    <subject value="zzzAdmin Logged Event" /> 
    <smtpHost value="email.zzz.com"/> 
    <bufferSize value="1"/> 
    <lossy value="false"/> 
    <authentication value="Basic" /> 

Loguję błąd jako html sformatowany tekst, ale klienci e-mail renderowania HTML jako zwykły tekst.

Jak mogę powiedzieć SMTPAppender dodać typ HTML do wiadomości e-mail, więc klienci będą renderować wiadomości jako HTML, który jest.

Odpowiedz

2

Wbudowany SmtpAppender nie obsługuje tego, więc będziesz musiał rzucić własną aplikację.

10

Od log4net nie wspiera formatu HTML w treści wiadomości tak daleko, napisałem własną appender:

using System; 
using System.Net.Mail; 
using log4net.Appender; 

namespace log4net.Appender 
{ 
    public class ExtendedSmtpAppender : SmtpAppender 
    { 
     public bool IsBodyHtml { get; set; } 

     protected override void SendEmail(string messageBody) 
     { 
      // .NET 2.0 has a new API for SMTP email System.Net.Mail 
      // This API supports credentials and multiple hosts correctly. 
      // The old API is deprecated. 

      // Create and configure the smtp client 
      SmtpClient smtpClient = new SmtpClient(); 
      if (!String.IsNullOrEmpty(SmtpHost)) 
      { 
       smtpClient.Host = SmtpHost; 
      } 
      smtpClient.Port = Port; 
      smtpClient.DeliveryMethod = SmtpDeliveryMethod.Network; 
      smtpClient.EnableSsl = EnableSsl; 

      if (Authentication == SmtpAuthentication.Basic) 
      { 
       // Perform basic authentication 
       smtpClient.Credentials = new System.Net.NetworkCredential(Username, Password); 
      } 
      else if (Authentication == SmtpAuthentication.Ntlm) 
      { 
       // Perform integrated authentication (NTLM) 
       smtpClient.Credentials = System.Net.CredentialCache.DefaultNetworkCredentials; 
      } 

      using (MailMessage mailMessage = new MailMessage()) 
      { 
       mailMessage.IsBodyHtml = IsBodyHtml; 
       mailMessage.Body = messageBody; 
       //mailMessage.BodyEncoding = BodyEncoding; 
       mailMessage.From = new MailAddress(From); 
       mailMessage.To.Add(To); 
       if (!String.IsNullOrEmpty(Cc)) 
       { 
        mailMessage.CC.Add(Cc); 
       } 
       if (!String.IsNullOrEmpty(Bcc)) 
       { 
        mailMessage.Bcc.Add(Bcc); 
       } 
       if (!String.IsNullOrEmpty(ReplyTo)) 
       { 
        // .NET 4.0 warning CS0618: 'System.Net.Mail.MailMessage.ReplyTo' is obsolete: 
        // 'ReplyTo is obsoleted for this type. Please use ReplyToList instead which can accept multiple addresses. http://go.microsoft.com/fwlink/?linkid=14202' 
#if !FRAMEWORK_4_0_OR_ABOVE 
        mailMessage.ReplyTo = new MailAddress(ReplyTo); 
#else 
        mailMessage.ReplyToList.Add(new MailAddress(m_replyTo)); 
#endif 
       } 
       mailMessage.Subject = Subject; 
       //mailMessage.SubjectEncoding = m_subjectEncoding; 
       mailMessage.Priority = Priority; 

       // TODO: Consider using SendAsync to send the message without blocking. This would be a change in 
       // behaviour compared to .NET 1.x. We would need a SendCompletedCallback to log errors. 
       smtpClient.Send(mailMessage); 
      } 
     } 
    } 
} 

Do użycia tej appender w log4net config, po prostu zastąpić przestrzeni nazw i nazwy klasy standardowy definicja SmtpAppender i dodać opcję isBodyHtml następująco:

<appender name="SmtpAppender" type="log4net.Appender.ExtendedSmtpAppender"> 
    ... 
    <isBodyHtml value="true" /> 
    ... 
</appender> 

źródłem metoda ciało SendEmail pochodzi z najnowszej wersji standardowy SmtpAppender standardu log4net. I tylko usuwa stare wersje ramy wspierające rzeczy i dodaje ten ciąg:

mailMessage.IsBodyHtml = IsBodyHtml; 

można uzyskać najnowszą wersję standard log4net's SmtpAppender here.

UPDATE:
Poniżej konfiguracji próbki (inspirowany these przykładach)

<log4net> 
    <!-- SmtpExAppender is set to be our ExtendedSmtpAppender --> 
    <appender name="SmtpExAppender" type="log4net.Appender.ExtendedSmtpAppender"> 
    <to value="[email protected]" /> 
    <from value="[email protected]" /> 
    <subject value="test logging message" /> 
    <isBodyHtml value="true" /> 
    <smtpHost value="SMTPServer.domain.com" /> 
    <bufferSize value="512" /> 
    <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> 

    <!-- Set root logger level to DEBUG and its only appender to SmtpExAppender --> 
    <root> 
    <level value="DEBUG" /> 
    <appender-ref ref="SmtpExAppender" /> 
    </root> 
</log4net> 
+0

Może związek źródło SmtpAppender powinien wskazywać [o] (http://svn.apache.org/ viewvc/logging/log4net/trunk/src/log4net/Appender/SmtpAppender.cs? view = log)? – Geoff

+0

@Geoff, Dzięki! Zaktualizowałem to. –

+0

czy możesz podać całą konfigurację, której potrzebuję? – user2783091