Вопрос по log4net, xml – Log4net xml output

15

Я хочу полный контроль над выходом log4net xml.

Как можно настроить шаблон вывода?

Ваш Ответ

3   ответа
3

это то, что вам нужно. Есть функция FormatXML, которую вам необходимо переопределить для предоставления XmlWriter правильно отформатированных данных.

3

в log4net 2.0.8 мне пришлось немного изменить макет:

<layout type="MyNamespace.MyClass, MyNamespace"/>

Я нашел это здесьhttp://www.codewrecks.com/blog/index.php/2008/04/29/writing-a-custom-formatter-for-log4net/

28

предложенный по MrPeregrination вам нужно написать класс, производный отXmlLayoutBaseпереопределитьFormatXml Метод и поручите вашему аппендеру использовать его в качестве макета:

class Program
{
    static void Main(string[] args)
    {
        XmlConfigurator.Configure();
        ILog log = log4net.LogManager.GetLogger(typeof(Program));
        log.Debug("Hello world");
    }
}

public class MyXmlLayout : XmlLayoutBase
{
    protected override void FormatXml(XmlWriter writer, LoggingEvent loggingEvent)
    {
        writer.WriteStartElement("LogEntry");
        writer.WriteStartElement("Message");
        writer.WriteString(loggingEvent.RenderedMessage);
        writer.WriteEndElement();
        writer.WriteEndElement();
    }
}

И в app.config положить это:

<?xml version="1.0" encoding="utf-8" ?>
<configuration>
  <configSections>
    <section name="log4net" type="log4net.Config.Log4NetConfigurationSectionHandler,log4net"/>
  </configSections>

  <log4net>
    <appender name="LogFileAppender" type="log4net.Appender.RollingFileAppender" >
      <param name="File" value="log.txt" />
      <param name="AppendToFile" value="true" />
      <rollingStyle value="Size" />
      <maxSizeRollBackups value="10" />
      <maximumFileSize value="10MB" />
      <staticLogFileName value="true" />
      <layout type="MyNamespace.MyXmlLayout" />
    </appender>

    <root>
      <level value="DEBUG" />
      <appender-ref ref="LogFileAppender" />
    </root>
  </log4net>
</configuration>

Это приведет к появлению таких записей в вашем файле журнала:

<LogEntry><Message>Hello world</Message></LogEntry>
Хорошо, решено раз и навсегда .. Оказывается, мне не нужно указывать пространство имен ... спасибо! JL.
Вы можете иметь этот класс в своей собственной библиотеке классов или в своей библиотеке классов приложения. Если он есть в его собственной библиотеке классов, вам нужно указать имя сборки, в которой он содержится: & lt; layout type = & quot; MyNamespace.MyXmlLayout, MyCustomLog4NetExtensions & quot; / & GT;
Как можно начинать и заканчивать теги по умолчанию для вывода: например & lt; start & gt; & lt; LogEntry & gt; ... & lt; / LogEntry & gt; & lt; LogEntry & gt; ... & lt; / LongEntry & gt; & lt; / start & gt; ??
Дарин, большое спасибо, наконец, дошло до сути, но не могли бы вы сказать мне, нужно ли мне иметь эту собственную базу макетов в своей собственной библиотеке классов, в моей библиотеке классов приложений или в библиотеке классов log4net (перекомпилировать) ? JL.

Похожие вопросы