Json.Net可以处理一个列表吗?

问题描述 投票:22回答:2
List<User> list = LoadUsers();

JObject json = new JObject();

json["users"] = new JValue(list);

似乎没有工作?

错误:

Could not determine JSON object type for type System.Collections.Generic.List`1
c# asp.net json json.net
2个回答
51
投票

JValue只能包含简单的值,如字符串,整数,布尔值,日期等。它不能包含复杂的对象。我怀疑你真正想要的是这个:

List<User> list = LoadUsers();

JObject json = new JObject();

json["users"] = JToken.FromObject(list);

以上将User对象列表转换为代表用户的JArrayJObjects,然后将其分配给新users上的JObject属性。你可以通过检查Typejson["users"]属性来确认这一点,看看它是Array

相反,如果您按照此问题的另一个答案(现已删除)中的建议执行json["users"] = new JValue(JsonConvert.SerializeObject(list)),您可能无法获得所需的结果。该方法将用户列表序列化为字符串,从中创建一个简单的JValue,然后将JValue分配给users上的JObject属性。如果你检查Typejson["users"]属性,你会发现它是String。这意味着,如果您稍后尝试使用JObjectjson.ToString()转换为JSON,您将获得双序列化输出而不是您可能期望的JSON。

这是一个简短的演示来说明差异:

class Program
{
    static void Main(string[] args)
    {
        List<User> list = new List<User>
        {
            new User { Id = 1, Username = "john.smith" },
            new User { Id = 5, Username = "steve.martin" }
        };

        JObject json = new JObject();

        json["users"] = JToken.FromObject(list);
        Console.WriteLine("First approach (" + json["users"].Type + "):");
        Console.WriteLine();
        Console.WriteLine(json.ToString(Formatting.Indented));

        Console.WriteLine();
        Console.WriteLine(new string('-', 30));
        Console.WriteLine();

        json["users"] = new JValue(JsonConvert.SerializeObject(list));
        Console.WriteLine("Second approach (" + json["users"].Type + "):");
        Console.WriteLine();
        Console.WriteLine(json.ToString(Formatting.Indented));
    }

    class User
    {
        public int Id { get; set; }
        public string Username { get; set; }
    }
}

输出:

First approach (Array):

{
  "users": [
    {
      "Id": 1,
      "Username": "john.smith"
    },
    {
      "Id": 5,
      "Username": "steve.martin"
    }
  ]
}

------------------------------

Second approach (String):

{
  "users": "[{\"Id\":1,\"Username\":\"john.smith\"},{\"Id\":5,\"Username\":\"steve.martin\"}]"
}

3
投票

我有这个问题,你现在可以使用JArray完成这个,如果你只是想要没有根名称的数组项。

var json = JArray.FromObject(LoadUsers());

如果您希望json数组的根名称为“users”,则可以使用

var json = new JObject { ["users"] = JToken.FromObject(LoadUsers()) };
© www.soinside.com 2019 - 2024. All rights reserved.