我有一个问题将JSON字符串反序列化为List
TCProject如下:
[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:{&#34;无法将JSON对象反序列化为类型&#39; System.Collections.Generic.List`1 [TCProject]&#39;。&#34;}
我必须有一些非常容易的东西,我不知道 - 有人有任何想法吗?
答案 0 :(得分:3)
我很确定你是否创建了一个带有一个名为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; }
}
答案 1 :(得分:0)
我认为在这种情况下你需要抓住JSON的数组部分来反序列化为这样的List:
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;
}