Невозможно сериализовать словарь с помощью сложного ключа с помощью Json.net

У меня есть словарь с пользовательским .net Тип как его ключ. Я пытаюсь сериализовать этот словарь в JSON с помощью JSON.net, но его невозможно преобразовать в правильное значение во время сериализации.

class ListBaseClass { public String testA; public String testB; } ----- var details = new Dictionary(); details.Add(new ListBaseClass { testA = "Hello", testB = "World" }, "Normal"); var results = Newtonsoft.Json.JsonConvert.SerializeObject(details); var data = Newtonsoft.Json.JsonConvert.DeserializeObject<Dictionary> results); 

Это дайте мне -> “{\” JSonSerialization.ListBaseClass \ “: \” Normal \ “}”

Однако, если у меня есть свой пользовательский тип как значение в словаре он хорошо работает

  var details = new Dictionary(); details.Add("Normal", new ListBaseClass { testA = "Hello", testB = "World" }); var results = Newtonsoft.Json.JsonConvert.SerializeObject(details); var data = Newtonsoft.Json.JsonConvert.DeserializeObject<Dictionary>(results); 

Это дайте мне -> “{\” Normal \ “: {\” testA \ “: \” Hello \ “, \” testB \ “: \” World \ “}}”

Может ли кто-нибудь предложить, если я нахожу какое-то ограничение Json.net, или я делаю что-то не так?

В разделе « Руководство по сериализации» (см. Раздел: Словари и Hashtables, спасибо @Shashwat за ссылку):

При сериализации словаря ключи словаря преобразуются в строки и используются в качестве имен свойств объекта JSON. Строку, написанную для ключа, можно настроить либо путем переопределения ToString () для типа ключа, либо путем реализации TypeConverter. TypeConverter также будет поддерживать преобразование пользовательской строки обратно при десериализации словаря.

Я нашел полезный пример того, как реализовать такой конвертер типов на странице «how-to» Microsoft:

  • Внедрение конвертера типов (см. Раздел Преобразователи типов для преобразования значений).

По сути, мне нужно было расширить System.ComponentModel.TypeConverter и переопределить:

 bool CanConvertFrom(ITypeDescriptorContext context, Type source); object ConvertFrom(ITypeDescriptorContext context, System.Globalization.CultureInfo culture, object value); object ConvertTo(ITypeDescriptorContext context, System.Globalization.CultureInfo culture, object value, Type destinationType); 

Также необходимо добавить атрибут [TypeConverter(typeof(MyClassConverter))] в объявление classа MyClass .

С их помощью я смог автоматически сериализовать и десериализовать словари.

Все проще

 var details = new Dictionary(); details.Add("Normal", new ListBaseClass { testA = "Hello", testB = "World" }); var results = Newtonsoft.Json.JsonConvert.SerializeObject(details.ToList()); var data = Newtonsoft.Json.JsonConvert.DeserializeObject> results); 

Образец

  class Program { static void Main(string[] args) { var testDictionary = new Dictionary() { { new TestKey() { TestKey1 = "1", TestKey2 = "2", TestKey5 = 5 }, new TestValue() { TestValue1 = "Value", TestValue5 = 96 } } }; var json = JsonConvert.SerializeObject(testDictionary); Console.WriteLine("=== Dictionary =="); Console.WriteLine(json); // result: {"ConsoleApp2.TestKey":{"TestValue1":"Value","TestValue5":96}} json = JsonConvert.SerializeObject(testDictionary.ToList()); Console.WriteLine("=== List> =="); Console.WriteLine(json); // result: [{"Key":{"TestKey1":"1","TestKey2":"2","TestKey5":5},"Value":{"TestValue1":"Value","TestValue5":96}}] Console.ReadLine(); } } class TestKey { public string TestKey1 { get; set; } public string TestKey2 { get; set; } public int TestKey5 { get; set; } } class TestValue { public string TestValue1 { get; set; } public int TestValue5 { get; set; } } 
  • Сериализация нескольких свойств DateTime в одном classе с использованием разных форматов для каждого из них
  • Json.Net: свойство Serialize / Deserialize в качестве значения, а не как объект
  • Сериализация / десериализация пользовательской коллекции с дополнительными свойствами с помощью Json.Net
  • C # JSON.NET - десериализация ответа, использующего необычную структуру данных
  • C # десериализация структуры после ее получения через TCP
  • Добавление к ObjectOutputStream
  • Исключение «Исключительная привязка к реляционной ссылке» с JSON.Net
  • Сериализация OpenCV Mat_
  • Невозможно десериализовать lambda
  • jackson не десериализует общий список, который он сериализовал
  • Когда и почему сущности JPA должны реализовывать интерфейс Serializable?
  • Давайте будем гением компьютера.