C# преобразование в DTO / JSON с использованием Automapper - PullRequest
0 голосов
/ 29 января 2020

Я пытаюсь вернуть JSON в этом формате из API с помощью Automapper:

  {
    "Name": "Jason",
    "Subjects":
      [
        "Maths":{
                  "CourseName": "Maths",
                  "Score": 70
                },
      "English":{
                  "CourseName": "English",
                  "Score": 80
                }
      ]
  }

Это специальный json, где мы можем видеть, что внутри объектов имя каждого субъекта на самом деле является CoursName недвижимость. Вот моя модель и DTO:

public class Student
{
    public string Name {get; set;}
    public ICollection Subjects {get; set;}
}

public class Subject
{
    public int Id {get; set;}
    public string CourseName {get; set;}
  public int Score {get; set;}
}

Проблема в субъектах. У каждого субъекта есть имя, полученное из CourseName, которое находится внутри объекта.

1 Ответ

0 голосов
/ 30 января 2020

Указанный вами JSON недействителен согласно jsonformatter.curiousconcept.com .

enter image description here

Этот код работает с действительным выводом JSON (RF C 8259).

using System.Collections.Generic;
using Newtonsoft.Json;

namespace JsonProgram
{
    public class Program
    {
        static void Main(string[] args)
        {
            var student = new Student
            {
                Name = "Jason",
                Subjects = new List<Subject>
                {
                    new Subject
                    {
                        Id = 1,
                        CourseName = "Maths",
                        Score = 70
                    },
                    new Subject
                    {
                        Id = 2,
                        CourseName = "English",
                        Score = 80
                    },
                }
            };
            var json = ToStudentJson(student);
        }

        private static string ToStudentJson(Student student)
        {
            var subjects = new List<Dictionary<string, SubjectBase>>();
            foreach (var subject in student.Subjects)
            {
                var dict = new Dictionary<string, SubjectBase>();
                dict.Add(subject.CourseName, new SubjectBase { CourseName = subject.CourseName, Score = subject.Score });
                subjects.Add(dict);
            }

            var studentJson = new StudentJson
            {
                Name = student.Name,
                Subjects = subjects.ToArray()
            };

            return JsonConvert.SerializeObject(studentJson);
        }
    }

    public class StudentJson
    {
        public string Name { get; set; }
        public Dictionary<string, SubjectBase>[] Subjects { get; set; }
    }
    public class Student
    {
        public string Name { get; set; }
        public ICollection<Subject> Subjects { get; set; }
    }

    public class Subject : SubjectBase
    {
        public int Id { get; set; }
    }

    public class SubjectBase
    {
        public string CourseName { get; set; }
        public int Score { get; set; }
    }
}

Выход:

{
    "Name": "Jason",
    "Subjects": [
        {
            "Maths": {
                "CourseName": "Maths",
                "Score": 70
            }
        },
        {
            "English": {
                "CourseName": "English",
                "Score": 80
            }
        }
    ]
}
...