控制台/FileAppender中的Log4net自定义json消息

控制台/FileAppender中的Log4net自定义json消息,log4net,log4net-appender,loggly,Log4net,Log4net Appender,Loggly,我需要使用log4net登录到多个目标(loggly、控制台、文件)。对于loggly,我需要登录JSON以获取一些元数据来查找日志。我通过向动态messageobject添加元数据来更改messageobject,如下所示(示例主题) 公共无效信息(字符串消息) { log.Info(GetLogObject(message)); } 私有对象GetLogObject(字符串消息,异常ex=null) { 动态对象=新的ExpandooObject(); obj.message=消息; obj

我需要使用log4net登录到多个目标(loggly、控制台、文件)。对于loggly,我需要登录JSON以获取一些元数据来查找日志。我通过向动态messageobject添加元数据来更改messageobject,如下所示(示例主题)

公共无效信息(字符串消息)
{
log.Info(GetLogObject(message));
}
私有对象GetLogObject(字符串消息,异常ex=null)
{
动态对象=新的ExpandooObject();
obj.message=消息;
obj.exception=ex;
obj.subject=_configuration.subject;
返回obj;
}
app.config

<log4net>
<root>
  <level value="ALL" />
  <appender-ref ref="ConsoleAppender" />
  <appender-ref ref="RollingFileAppender" />
  <appender-ref ref="LogglyAppender" />
</root>
<appender name="ConsoleAppender" type="log4net.Appender.ConsoleAppender">
  <layout type="log4net.Layout.PatternLayout">
    <conversionPattern value="%date - %message%newline" />
  </layout>
</appender>
<appender name="LogglyAppender" type="log4net.loggly.LogglyAppender, log4net-loggly">
  <rootUrl value="https://logs-01.loggly.com/" />
  <inputKey value="*" />
  <tag value="AppTag" />
  <filter type="log4net.Filter.LevelRangeFilter">
    <levelMin value="ERROR" />
    <levelMax value="FATAL" />
  </filter>
</appender>
<appender name="RollingFileAppender" type="log4net.Appender.RollingFileAppender">
  <file value="Logs/rolling.log" />
  <appendToFile value="true" />
  <rollingStyle value="Size" />
  <maxSizeRollBackups value="5" />
  <maximumFileSize value="10MB" />
  <staticLogFileName value="true" />
  <layout type="log4net.Layout.PatternLayout">
    <conversionPattern value="%date %level - %message%newline" />
  </layout>
</appender>
我希望这些附加器只记录消息本身(obj.message),如下所示:

2017-06-12 15:28:10,236 INFO - Will collect every 1 Hours, 0 Minutes and 0 Seconds
2017-06-12 15:28:10,271 INFO - Collection Round started at 12.06.2017 11:17:29
我该怎么做?
非常感谢:)

如果为消息对象创建自己的类型(而不是使用动态对象),并重写
ToString()
方法,会发生什么?我怀疑,
LogglyAppender
会呈现图形,而常规的
patternayout
会求助于
ToString()
。我没有试过这个,只是一个提示。您也许可以将
ExpandoObject
子类化,以避免失去这种动态性

2017-06-12 15:28:10,236 INFO - Will collect every 1 Hours, 0 Minutes and 0 Seconds
2017-06-12 15:28:10,271 INFO - Collection Round started at 12.06.2017 11:17:29