使用“空格”分隔的属性名称反序列化 JSON

The*_*der 5 c# asp.net

我需要反序列化一个 json,它的属性名称之间有一个“空格” (“关联团队”和“联系点”)。我尝试通过创建强类型对象来反序列化 json 字符串,但无法映射这 2 个属性。

JSON 字符串:(jsonString)

{
  "id": "/subscriptions/911yyy-1234-4695-a90f-943xxxxxxx/resourceGroups/sample",
  "name": "sample",
  "type": null,
  "properties": {
    "provisioningState": "Succeeded"
  },
  "location": "westus",
  "tags": {
    "Associated Team": "Sample Team",
    "Description": "Resource Group for Azure",
    "Point of Contact": "abc@xyz.com"
  }
}
Run Code Online (Sandbox Code Playgroud)

.Net 代码片段:

var deserializedResourceGroupDetails = JsonConvert.DeserializeObject<AzureResourceData>(jsonString);
Run Code Online (Sandbox Code Playgroud)

AzurResourceData.cs 类:

public class Tags
    {
        [JsonProperty("associatedTeam")]
        public string associatedTeam { get; set; }
        public string description { get; set; }
        [JsonProperty("pointOfContact")]
        public string pointOfContact { get; set; }
    }

    public class Properties
    {
        public string provisioningState { get; set; }
    }

    public class AzureResourceData
    {
        public string id { get; set; }
        public string name { get; set; }
        public string location { get; set; }
        public Tags tags { get; set; }
        public Properties properties { get; set; }
    }
Run Code Online (Sandbox Code Playgroud)

我也尝试过动态反序列化 json(如下),但是我再次无法获取这两个属性的值,因为它们的名称之间有空格。

dynamic deserializedResourceGroupDetails = JsonConvert.DeserializeObject(jsonString))); 
Run Code Online (Sandbox Code Playgroud)

小智 5

您的 [JsonProperty] 应该与您的 JSON 对象的键完全匹配。所以你的标签类应该是这样的:

public class Tags
{
    [JsonProperty("Associated Team")]   //this one changed
    public string associatedTeam { get; set; }
    public string description { get; set; }
    [JsonProperty("Point of Contact")]  //this one too
    public string pointOfContact { get; set; }
}
Run Code Online (Sandbox Code Playgroud)

这样,JSON 就知道将文件中那些实际上不在代码中的键映射到何处。