1

我正在NLog将日志记录语句持久化到我的RavenDb数据库中。表示日志语句的LogEventInfo类有一个属性 ,LogLevel和一个私有构造函数。LogLevel(Info、Warn 等)的实例是通过调用私有构造函数的静态只读属性创建的。

问题是我希望从数据库中读取消息并查询它们会引发Json.Net序列化错误:

找不到用于 NLog.LogLevel 类型的构造函数。一个类应该有一个默认构造函数、一个带参数的构造函数或一个标有 JsonConstructor 属性的构造函数。路径'Level.Name'。

我怎样才能绕过错误?可以在这里创建某种 Raven 索引帮助吗?

4

2 回答 2

1

我认为最简单的方法是创建一个自定义类来保存所有日志信息。

于 2013-03-10T22:37:12.873 回答
1

它像这样和我一起工作

创建一个 CustomCreationConverter并将其与对象的反序列化一起使用

public class EventInfoConverter : CustomCreationConverter<LogEventInfo>
    {
        private string _level { get; set; }
        public EventInfoConverter(string s)
        {
            JToken eventinfo = JObject.Parse(s);
            var childs = eventinfo.Children();
            foreach (var item in childs)
            {
                if (((Newtonsoft.Json.Linq.JProperty)item).Name == "Level")
                {
                    var m = ((Newtonsoft.Json.Linq.JProperty)item).Value.Children();
                    foreach (var item1 in m)
                    {
                        _level = ((Newtonsoft.Json.Linq.JProperty)item1).Value.ToString();
                        break;
                    }

                    break;
                }
            }
        }

        public override LogEventInfo Create(Type objectType)
        {
            LogEventInfo eventInfo = new LogEventInfo();
            switch (_level)
            {
                case "Info":
                         eventInfo = new LogEventInfo(LogLevel.Info, "", "");
                    break;
                case "Debug":
                    eventInfo = new LogEventInfo(LogLevel.Debug, "", "");
                    break;
                case "Error":
                    eventInfo = new LogEventInfo(LogLevel.Error, "", "");
                    break;
                case "Warn":
                    eventInfo = new LogEventInfo(LogLevel.Warn, "", "");
                    break;
                default:
                    break;
            }
            return eventInfo;
        }
    }
  • 在您的反序列化中:

    NLog.Logger _logger = NLog.LogManager.GetCurrentClassLogger();
    _logger.Log(Newtonsoft.Json.JsonConvert.DeserializeObject<LogEventInfo>(eventInfo, new EventInfoConverter(eventInfo)));
    
于 2017-12-11T12:10:26.580 回答