Рейтинговые книги
Читем онлайн Язык программирования C#9 и платформа .NET5 - Троелсен Эндрю

Шрифт:

-
+

Интервал:

-
+

Закладка:

Сделать
1 ... 372 373 374 375 376 377 378 379 380 ... 642

<b>  [JsonInclude]</b>

  public bool IsHatchBack;

  ...

}

// JamesBondCar.cs

public class JamesBondCar : Car

{

  [XmlAttribute]

<b>  [JsonInclude]</b>

  public bool CanFly;

  [XmlAttribute]

<b>  [JsonInclude]</b>

  public bool CanSubmerge;

  ...

}

// Person.cs

public class Person

{

  // Открытое поле.

<b>  [JsonInclude]</b>

  public bool IsAlive = true;

  ...

}

Теперь в результате запуска кода любым способом все открытые свойства и поля записываются в файл. Однако, заглянув содержимое файла, вы увидите, что данные JSON были записаны в минифицированном виде, т.е. в формате, в котором все незначащие пробельные символы и разрывы строк удаляются. Формат является стандартным во многом из-за широкого использования JSON для служб REST и уменьшения размера пакета данных при передаче информации между службами по HTTP/HTTPS.

На заметку! Поля для сериализации JSON обрабатываются точно так же, как для десериализации JSON. Если вы выбирали вариант включения полей при сериализации JSON, то также должны делать это при десериализации JSON.

Понятный для человека вывод данных JSON

В дополнение к варианту с включением открытых полей экземпляр класса JsonSerializer можно проинструктировать о необходимости записи данных JSON с отступами (для удобства чтения человеком). Модифицируйте свой метод, как показано ниже:

static void SaveAsJsonFormat&lt;T&gt;(T objGraph, string fileName)

{

  var options = new JsonSerializerOptions

  {

    IncludeFields = true,

<b>    WriteIndented = true</b>

  };

  File.WriteAllText(fileName,

     System.Text.Json.JsonSerializer.Serialize(objGraph, options));

}

Заглянув в файл CarData.json, вы заметите, что вывод стал гораздо более читабельным:

{

  &quot;CanFly&quot;: true,

  &quot;CanSubmerge&quot;: false,

  &quot;TheRadio&quot;: {

    &quot;HasTweeters&quot;: true,

    &quot;HasSubWoofers&quot;: false,

(window.adrunTag = window.adrunTag || []).push({v: 1, el: 'adrun-4-390', c: 4, b: 390})

    &quot;StationPresets&quot;: [

      89.3,

      105.1,

      97.1

    ],

    &quot;RadioId&quot;: &quot;XF-552RR6&quot;

  },

  &quot;IsHatchBack&quot;: false

}

Именование элементов JSON в стиле Pascal или в "верблюжьем" стиле

Стиль Pascal представляет собой формат, в котором первый символ и каждая важная часть имени начинается с символа в верхнем регистре. В предыдущем листинге данных JSON примером стиля Pascal служит CanSubmerge. В "верблюжьем" стиле, с другой стороны, для первого символа применяется нижний регистр, а все важные части имени начинаются с символа в верхнем регистре. Версия предыдущего примера в "верблюжьем" стиле выглядит как canSubmerge.

Почему это важно? Дело в том, что большинство популярных языков (в том числе С#) чувствительно к регистру. Таким образом, CanSubmerge и canSubmerge — два разных элемента. Повсюду в книге вы видели, что общепринятым стандартом для именования открытых конструкций в C# (классов, открытых свойств, функций и т.д.) является использование стиля Pascal. Тем не менее, в большинстве фреймворков JavaScript задействован "верблюжий" стиль. В итоге могут возникать проблемы при использовании .NET и C# для взаимодействия с другими системами, например, в случае передачи данных JSON туда и обратно между службами REST.

К счастью, JsonSerializer допускает настройку для поддержки большинства ситуаций, в том числе отличий в стилях именования. Если политика именования не указана, то JsonSerializer при сериализации и десериализации JSON будет применять стиль Pascal. Чтобы заставить процесс сериализации использовать "верблюжий" стиль, модифицируйте параметры, как показано ниже:

static void SaveAsJsonFormat&lt;T&gt;(T objGraph, string fileName)

{

  JsonSerializerOptions options = new()

  {

<b>    PropertyNamingPolicy = JsonNamingPolicy.CamelCase,</b>

    IncludeFields = true,

    WriteIndented = true,

  };

  File.WriteAllText(fileName,

      System.Text.Json.JsonSerializer.Serialize(objGraph, options));

}

Теперь выпускаемые данные JSON будут представлены в "верблюжьем" стиле:

{

  &quot;canFly&quot;: true,

  &quot;canSubmerge&quot;: false,

  &quot;theRadio&quot;: {

1 ... 372 373 374 375 376 377 378 379 380 ... 642
На этой странице вы можете бесплатно читать книгу Язык программирования C#9 и платформа .NET5 - Троелсен Эндрю бесплатно.
Похожие на Язык программирования C#9 и платформа .NET5 - Троелсен Эндрю книги

Оставить комментарий