簡體   English   中英

從 ServiceNow Rest ZDB974238714CA8DE1434A7CE1DZFZ83A 訪問 C# 中的 JSON 密鑰

[英]Access JSON keys in C# from ServiceNow Rest API

我正在調用 ServiceNow Incidents 表並撤回一個這樣的事件。 https://mydevInstance.service-now.com/api/now/v1/table/incident?sysparm_limit=1

var client = new RestClient("https://mydevInstance.service-now.com/api/now/v1/table/incident?sysparm_limit=1");
client.Timeout = -1;
var request = new RestRequest(Method.GET);
request.AddHeader("Authorization", "Basic myAuthKey");
IRestResponse response = client.Execute(request);

它在 RESTSharp 中返回的 JSON 看起來像這樣。

{
    "result": [
        {
            "parent": "",
            "made_sla": "true",
            "caused_by": "",
            "watch_list": "",
            "upon_reject": "cancel",
            "resolved_by": {
                "link": "https://mydevInstance.service-now.com/api/now/v1/table/sys_user/5137153cc611227c000bbd1bd8cd2007",
                "value": "5137153cc611227c000bbd1bd8cd2007"
            },
            "approval_history": "",
            "number": "INC0000060"
        }
    ]
}

如何創建 C# 列表或結果下所有鍵的數組? 我無法用 JSON.Net 序列化 object,因為隨着時間的推移,可以添加其他密鑰。

您需要獲取 JSON 內容的樣本,然后使用我描述的“Paste Special”選項制作 C# class。

菜單選項

Then you can use the JsonConvert.DeserializeObject<T> (in a nuget package by Newtonsoft) to deserialize your web service response in a C# object instance.

這是我使用您的 JSON object 生成的 C# 類,未更改:

public class Rootobject
{
    public Result[] result { get; set; }
}

public class Result
{ 
    public string parent { get; set; }
    public string made_sla { get; set; }
    public string caused_by { get; set; }
    public string watch_list { get; set; }
    public string upon_reject { get; set; }
    public Resolved_By resolved_by { get; set; }
    public string approval_history { get; set; }
    public string number { get; set; }
}

public class Resolved_By
{
    public string link { get; set; }
    public string value { get; set; }
}

您可以像這樣使用這種類型:

var json = "t-b-d"; // From Web Service call
Rootobject response = JsonConvert.DeserializeObject<Rootobject>(json);
// use the response object.

** 更新 **

如果你需要更靈活的 model,所有的 JSON 都會反序列化成Dictionary<string, string> ,但是我發現當 Z20F35E630DAF4399D8C 一致時,序列化/反序列化結果更可靠

var response = JsonConvert.DeserializeObject<Dictionary<string,string>>(json);

這是使用 System.Text.Json 的工作原理

var incidentFields = new List<string>();

var doc = JsonDocument.Parse(json);
foreach (var o in doc.RootElement.GetProperty("result").EnumerateArray())
{
    foreach (var p in o.EnumerateObject())
    {
        incidentFields.Add(p.Name.ToString());
    }
}

我創建了一個默認處理的庫。 (您也可以添加自定義類型)

https://emersonbottero.github.io/ServiceNow.Core/

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM