c#中JSON格式字符串的值(来自REST API)
本文关键字:来自 REST API JSON 格式 字符串 | 更新日期: 2023-09-27 18:16:20
最近我得到了一个约会,我需要使用它的REST API从云下载一些数据,并将该"字符串"的值存储在对象或一些变量中。下载完成了,现在我需要做的就是以某种方式解析数据。
到现在为止,我做了这样的代码:
HttpWebRequest request = (HttpWebRequest)WebRequest.Create("some link");
request.ContentType = "application/json; charset=utf-8";
request.Method = "GET";
request.Headers.Add("Carriots.apiKey", "key");
using (WebResponse response = request.GetResponse())
{
using(Stream stream = response.GetResponseStream())
{
StreamReader reader = new StreamReader(stream);
JObject json = JObject.Parse(reader.ReadToEnd());
Console.WriteLine(json.ToString());
}
}
输出如下:
{
"total_documents": 3,
"result": [
{
"_id": "...",
"protocol": "v1",
"checksum": "",
"_t": "str",
"at": 1444134377,
"device": "-just a device-",
"data": {
"field1": "123",
"field2": "1536"
},
"id_developer": "....",
"created_at": 1444134377,
"owner": "-someUser-"
}
]
}
我知道互联网上有很多解决方案,但没有一个能满足我的需要。好的,我找到了一些东西,但它会在每行上迭代并以这种方式检查值,但在我的例子中,我可以有数千个这样的输出。
是否有任何方法可以使用某种内置函数或唯一的解决方案是迭代或编写一些正则表达式来完成所有这些(我的意思是解析)?
假设json将始终遵循此格式,定义您的模型
public class jsonData{
public int total_documents {get;set;}
public resultData result {get;set;}
}
public class resultData{
public int _id {get;set;}
public string protocol {get;set;}
....
}
则使用反序列化
Json.Deserialize<jsonData>(yourstring)