Проблема десериализации JSON в список <T> - PullRequest
4 голосов
/ 12 июля 2011

У меня проблема с десериализацией строки JSON в список

Проект TCP выглядит следующим образом:

[JsonObject(MemberSerialization.OptIn)]
    public class TCProject
    {
        public override string ToString()
        {
            return Name;
        }

        [JsonProperty(PropertyName = "archived")]
        public bool Archived { get; set; }

        [JsonProperty(PropertyName = "description")]
        public string Description { get; set; }

        [JsonProperty(PropertyName = "href")]
        public string Href { get; set; }

        [JsonProperty(PropertyName = "id")]
        public string Id { get; set; }

        [JsonProperty(PropertyName = "name")]
        public string Name { get; set; }

        [JsonProperty(PropertyName = "webUrl")]
        public string WebUrl { get; set; }
    }

Строка JSON выглядит следующим образом:

{"project":[{"name":"GCUK","id":"project11","href":"/httpAuth/app/rest/projects/id:project11"},{"name":"Interiors In Spain","id":"project3","href":"/httpAuth/app/rest/projects/id:project3"}]}

код для преобразования строки выглядит следующим образом:

public IEnumerable<TCProject> GetAllProjects()
        {
            var uri = _connection.CreateUri("/httpAuth/app/rest/projects");
            var request = _connection.Request(uri);

            var projects = JsonConvert.DeserializeObject<List<TCProject>>(request);

    return projects;
}

Исключение, которое я получаю:

Newtonsoft.Json.JsonSerialisationException: {"Невозможно десериализовать объект JSON в тип 'System.Collections.Generic.List`1 [TCProject]'."}

должно быть что-то действительно простое, что я пропускаю - у кого-нибудь есть идеи?

Ответы [ 2 ]

3 голосов
/ 12 июля 2011

Я почти уверен, что если вы создали класс с одним свойством с именем project, который был List и десериализован для этого объекта, все бы сработало.

//Using a page "test.aspx" in my existing project (I already had it open)
using System;
using System.Collections.Generic;
using Newtonsoft.Json;

public partial class test : System.Web.UI.Page
{
    protected void Page_Load(object sender, EventArgs e)
    {
        string s = "{\"project\":[{\"name\":\"GCUK\",\"id\":\"project11\",\"href\":\"/httpAuth/app/rest/projects/id:project11\"},{\"name\":\"Interiors In Spain\",\"id\":\"project3\",\"href\":\"/httpAuth/app/rest/projects/id:project3\"}]}";
        var p = JsonConvert.DeserializeObject<TCProjectWrapper>( s );
        s = "this"; //for easy breakpointing
    }
}
[JsonObject( MemberSerialization.OptIn )]
public class TCProjectWrapper {
    [JsonProperty( PropertyName = "project" )]
    private List<TCProject> Project { get; set; }
}
[JsonObject( MemberSerialization.OptIn )]
public class TCProject {
    public override string ToString() {
        return Name;
    }

    [JsonProperty( PropertyName = "archived" )]
    public bool Archived { get; set; }

    [JsonProperty( PropertyName = "description" )]
    public string Description { get; set; }

    [JsonProperty( PropertyName = "href" )]
    public string Href { get; set; }

    [JsonProperty( PropertyName = "id" )]
    public string Id { get; set; }

    [JsonProperty( PropertyName = "name" )]
    public string Name { get; set; }

    [JsonProperty( PropertyName = "webUrl" )]
    public string WebUrl { get; set; }
}
0 голосов
/ 12 июля 2011

Я думаю, что в этом случае вам нужно взять только часть массива JSON, чтобы десериализовать его в список следующим образом:

    public IEnumerable<TCProject> GetAllProjects()
    {
        var uri = _connection.CreateUri("/httpAuth/app/rest/projects");
        var request = _connection.Request(uri);

        var projects = JsonConvert.DeserializeObject<List<TCProject>>(request.Substring(11, request.Length - 1));

        return projects;
    }
...