使用 Json.NET 反序列化一个空数组

bmt*_*033 4 c# json.net deserialization

我有一个使用 Json.NET v7.0.1 的 C# 应用程序。作为 REST 调用的结果,我以以下形式返回了一些 JSON:

{
"messages": [ {"phoneNumber":"123-456-7890", "smsText":"abcd1234="},
              {"phoneNumber":"234-567-8901", "smsText":"efgh5678="},
              {"phoneNumber":"345-678-9012", "smsText":"12345asdf"} ]
}
Run Code Online (Sandbox Code Playgroud)

如果没有要返回的消息数据,返回的 JSON 如下所示:

{
"messages": [ ]
}
Run Code Online (Sandbox Code Playgroud)

我的 Message 类如下所示:

public class Message
{
    public string PhoneNumber { get; set; }
    public string SmsText { get; set; }

    public Message()
    {
    }

    public Message(string phoneNumber, string smsText)
    {
        PhoneNumber = phoneNumber;
        SmsText = smsText;
    }
}
Run Code Online (Sandbox Code Playgroud)

当我尝试反序列化 JSON 时,我使用了以下代码:

Message[] messages = JsonConvert.DeserializeObject<Message[]>(json, new JsonSerializerSettings
{
    MissingMemberHandling = MissingMemberHandling.Ignore
});
Run Code Online (Sandbox Code Playgroud)

我遇到的问题是当消息数组为空时反序列化 JSON。发生这种情况时,我收到以下异常:

无法将当前 JSON 对象(例如 {\"name\":\"value\"})反序列化为类型“WindowsFormTestApplication.Message[]”,因为该类型需要 JSON 数组(例如 [1,2,3])来反序列化正确。\r\n要修复此错误,请将 JSON 更改为 JSON 数组(例如 [1,2,3])或更改反序列化类型,使其成为正常的 .NET 类型(例如,不是像整数这样的原始类型,不是可以从 JSON 对象反序列化的集合类型(如数组或列表)。还可以将 JsonObjectAttribute 添加到类型以强制它从 JSON 对象反序列化。路径“消息”,第 2 行,位置 15。

当 JSON 数组为空时,我希望我的 Message[] 变量为空。我需要一个自定义转换器来反序列化还是我遗漏了一些明显的东西?谢谢!

Mar*_*ich 7

您应该只发送一个数组

[ {"phoneNumber":"123-456-7890", "smsText":"abcd1234="},
              {"phoneNumber":"234-567-8901", "smsText":"efgh5678="},
              {"phoneNumber":"345-678-9012", "smsText":"12345asdf"} ]
Run Code Online (Sandbox Code Playgroud)

或者像这样使用一些包装对象

public WrapperObject 
{ 
    public Message[] messages { get; set; } 
}
Run Code Online (Sandbox Code Playgroud)

然后反序列化使用它

var wrapper = JsonConvert.DeserializeObject<WrapperObject>(json, new JsonSerializerSettings
    {
        MissingMemberHandling = MissingMemberHandling.Ignore
    });
Run Code Online (Sandbox Code Playgroud)