从 ServiceNow Rest API 访问 C# 中的 JSON 键
Access JSON keys in C# from ServiceNow Rest API
我正在调用 ServiceNow 事件 table 并撤回一个这样的事件。 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 它 returns 看起来像这样。
{
"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 序列化对象,因为随着时间的推移可以添加其他键。
您需要获取 JSON 内容的示例,然后使用我描述的 'Paste Special' 选项制作 C# class。
然后您可以使用 JsonConvert.DeserializeObject<T>
(在 Newtonsoft 的 nuget 包中)在 C# 对象实例中反序列化您的 Web 服务响应。
这是我用你的 JSON 对象生成的未更改的 C# classes:
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.
** 已更新 **
如果你需要更灵活的模型,所有JSON都会反序列化成Dictionary<string, string>
,但我发现在模型一致的情况下序列化/反序列化结果更可靠
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());
}
}
我创建了一个默认处理该问题的库。 (您也可以添加自定义类型)
我正在调用 ServiceNow 事件 table 并撤回一个这样的事件。 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 它 returns 看起来像这样。
{
"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 序列化对象,因为随着时间的推移可以添加其他键。
您需要获取 JSON 内容的示例,然后使用我描述的 'Paste Special' 选项制作 C# class。
然后您可以使用 JsonConvert.DeserializeObject<T>
(在 Newtonsoft 的 nuget 包中)在 C# 对象实例中反序列化您的 Web 服务响应。
这是我用你的 JSON 对象生成的未更改的 C# classes:
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.
** 已更新 **
如果你需要更灵活的模型,所有JSON都会反序列化成Dictionary<string, string>
,但我发现在模型一致的情况下序列化/反序列化结果更可靠
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());
}
}
我创建了一个默认处理该问题的库。 (您也可以添加自定义类型)